برمجة متفمة Vv‏ المحتوى الكامل للمادة 


أساسيات الاتصالات المحمولة 
الكلمات المفتاحية: 


محمول» لاسلکی› تقنية» تجهيزات» مزود الخدمة. 


ملخض : 
تعتبر التقنيات المحمولة موضوع اهتمام كبير للمطورين لما لها من انعكاس على التطبيقات التي يمكن أن تستثمّر فيها. سنحاول في هذه 
الجلسة التعرف على المفاهيم الأساسية للتقنيات المحمولة وتطبيقاتها في التجارة والأعمال الالكترونية. 


أهداف تعليمية: 
يتعرف الطالب في هذا الفصل على : 
مفهوم التقنيات المحمولة واللاسلكية 
٠‏ التجهيزات المحمولةء أنواعها ومواصفاتها 
مفهوم التجارة الالكترونية باستخدام التجهيزات المحمولة ومعيقاتها. 
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التقنيات المحمولة واللاسلكية 


0 


تعریف: 
يختلف تعريف مصطلحي المحمول واللاسلكي من شخص إلى آخر ومن منظومة إلى أخرى. 
بُستخدم هذان المصطلحان عادة بطريقة تبادلية بالرغم من كونهما يُعبران عن تقنيتين مختلفتين. 


التقنيات المحمولة هي أية تقنية يمكن استخدامها أثتاء الحركة وهي تتدرج من الحواسب المحمولة إلى الهواتف الخليوية بمعنى أنه 
مادمنا لا نتحدث عن تبات في الموقع فنحن نتحدث عن تفنية محمولة. 


في حين يعبر المصطلح (لاسلكي) عن عملية الإرسال لصوت أولبيانات باستخدام موجات راديوية. إذ تسمح التقنيات اللاسلكية للعاملين 
في مؤسسة ما مثلاً بالوصول إلى بيانات المؤسسة دون الحاجة إلى اتصال فيزيائي ملموس مع الشبكة. بالنتيجةء تشكل التجهيزات التي 
تتصل ببعضها البعض بهذا الأسلوب ما يُسمى الشبكة اللاسلكية. 

إذاً يمكننا القول أن التقنيات اللاسكلية تشمل كل ما يمكن استخدامه لإرسال أواستقبال البيانات عبر الشبكة اللاسلكية. 


يمكن الاتصال بالشبكات اللاسكلية باستخدام تقنية محمولة أومن موقع ثابت. 


كما نرى في معظم الأحيان تعتبر التقنيات اللاسلكية مجموعة جزئية من التقنيات المحمولة ولكن في بعض الأحيان يمكن لأحد 
التجهيزات أن يُمتل تقنية محمولة دون أن يكون لاسلكياً. يوضح الشكل التالي العلاقة بين التقنيات المحمولة واللاسلكية. 


مكونات بيئة العمل اللاسلكية 


تتطلب عملية تأمين بيئة عمل لاسلكية تضافر مجموعة من الخدمات والتطبيقات من جهة وتدخل أطراف من جهة أخرى بحيث تشكل 
هذه الأطراف بمجملها سلسلة مكونات بيئة العمل. 


يظهر الشكل التالي هذه المكونات: 
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ال ا 


ومزودو الخدمة 


المُشغل اللاسلكي ومزود الخدمة: 
يتطلب أي حل لاسلكي مشعل أومزود خدمةء وهوما يتمثل بشركة تؤمن البنية التحتية للاتصال عبر شبكة لاساكية عريضة أومحلية. 
تكون أغلب هذه الشركات هي نفسها الشركات التي تقدم خدمات الاتصال للهواتف المحمولة وللاتصالات الصوتية. 


بائعوا العتاد الصلب: 
تحتاج الحلول اللاسلكية عادة بالإضافة إلى التجهيزات المحمولةء عتاداً صلباً إضافياً. يشمل هذا العتاد تجهيزات مثل الموائمات 
اللاسلكية وبطاقات الشبكة ونقاط الوصول اللاسلكية. 

بدأت مؤخراً محاولة تضمين التجهيزات المحمولة هذا العتاد بشكل مبيت ولكن سيلزم بعض الوقت لتصبح هذه العملية قياسية في كل 
التجهيزات المحمولة. 


مزودوا البنية التحتية البرمجية: 


يوفر مزود الخدمة والعتاد بيئة فيزيائية للعمل ولكن الحل لا يتكامل دون وجود بيئة برمجية للعمل. فمن الضروري مثلا وجود متصفح 
انترنت» وبرنامج مخدم تطبيقات لاسلكيةء وتطبيق لإدارة عمليات التخزين وغيرهاء حتى نحصل على حل متكامل. 


مكونات بيئة العمل اللاسلكية 
(نتمة) 
بائعوا البرمجيات المستقلون : 
إضافة إلى برمجيات البنية التحتيةء تقدم العديد من الشركات برمجيات خاصة بخدمة أوغرض معين مثل برمجيات حساب الضرائب» 
وبرمجيات الخدمات المصرفية» وبرمجيات الخدمات الصحية»ء... وغيرها. 


مكاملوا الأنظمة : 
وهر مجنرهة الق ر كات التي فطاع في تشي خر مة مقاط من المكرقات اتسيف النكرء فى سل المقال تر كز الد من هذه 
الشركات طى تشيم الأول اللهلكة المحمرنة العامة 


مصنعوا التجهيزات: 
تعتبر التجهيزات المحمولة متطلباً رئيسياً في حلول الثقنيات المحمولة. ويتوقف اختيار التجهيزات المناسبة على نوع التطبيقات المراد 
التعامل معهاء حيث تعتبر أجهزة ۶0۸ وأجهزة الحواسب المحمولة أكثر ملائمة في حلول الأعمال المحمولة من الهواتف المحمولةء 
لكونها تكون قادرة على تشغيل تطبيقات أكثر تعقيداً ولكونها تمتلك واجهة ملائمة أكثر لطبيعة هذه التطبيقات ( سيتغير هذا الوضع مع 
ظهور الهواتف المحمولة الذكية والتي دمجت طبيعة عمل أجهزة ۲5۸ مع مميزات الهاتف العادي). 
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لا تكون جميع هذه المكونات مطلوبة في كافة الحلول المحمولةء إذ يمكن استخدام مجموعة جزئية فقط من مكونات هذه السلسلة لتقديم 
بعض الحلول. 
التجهيزات المحمولة 


يقدم سوق التجهيزات المحمولة طيفاً واسعاً من التجهيزات المحمولة والموجهة لتغطية الأنواع المختلفة من التطبيقات والمستخدمين. 
تتدرج هذه التجهيزات في الكلفة والحجم وتغطي أنواع الحواسب المحمولة وأجهزة ۴24 والهواتف الذكية... وغيرها. 


تكتسب التجهيزات المحمولة أهميتها من كونها الجزء الوحيد من الحلول المحمولة الذي يكون على تماس مباشر مع المستخدم. لذا 
يجب» عند تصميم أي حل محمول» مراعاة خصائص هذه التجهيزات من حيث آلية الاتصال» ونظام التشغيل» وآليات الإدخال» 
ومستوى الأداء. 
كما يجب مراعاة النقاط التالية: 

حجم الجهاز ووزنه 

سرعة المعالجة 

مواصفات الشاشة من حيث الحجم والألوان وإمكانية الاستخدام الداخلي أوالخارجي 

إمكانية تحديث نظام التشغيل 

إمكانية وصل الطرفيات والتوسّع 

عمر البطارية 

التقنيات المّدمَجة في الجهاز كوجود كاميرا أولوحة مفاتيح» أوأشعة تحت حمراءء أواتصال لاسلكي من نمط بلوتوث 

الدعم البرمجي بما يتضمن توفر برمجيات مُطوّرة من شركات مختلفة عن الجهة المصنعة. 


التجهيزات المحمولة 


من بين الخصائص التي ر أيناها للتجهيزات المحمولة والتي يجب مراعاتها في تصميم الحلول المحمولةء تكتسب آلية الإدخال وآلية 
الاتصال اللاسلكية أهمية كبيرة مما سيجعانا نناقشها بصورة أكثر تفصيلا. 


آلية الإدخال: 

تعتمد آلية الإدخال التي يجب اختيارها في التجهيزات المحمولة على مستوى التفاعل المطلوب» وعلى نوع التطبيقات التي نريد التعمل 
معهاء عموماًء تستلزم معظم تطبيقات الأعمال المحمولة كمية كبيرة من الإدخالات لذلك يجب أخذ آلية الإدخال بعين الاعتبار في هذا 
النوع من الحلول. 


آليات الإدخال الآكثر انتشاراً هي: 
٠‏ لوحة الأرقام 
٠‏ الإدخال باستخدام القلم 
ه لوحة المفاتيح الافتراضية 
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ه التعرف على المحارف 

٠ ©‏ مخفو عة مكارف 

ه التعرف المباشر على خط اليد. 
٠‏ الإدخال باستخدام لوحة المفاتيح 
٠‏ الإدخال الصوتي. 


من بين الخصائص التي رأيناها للتجهيزات المحمولة والتي يجب مراعاتها في تصميم الحلول المحمولةء تكتسب آلية الإدخال وآلية 
الاتصال اللاساكية أهسة كبير 3 مما سيجعانا تناقشها نضورة أكثر تفصيا. 

آلية الإدخال: 

تعتمد آلية الإدخال التي يجب اختيارها في التجهيزات المحمولة على مستوى التفاعل المطلوب» وعلى نوع التطبيقات التي نريد التعمل 
معهاء عموماًء تستلزم معظم تطبيقات الأعمال المحمولة كمية كبيرة من الإدخالات لذلك يجب أخذ آلية الإدخال بعين الاعتبار في هذا 
النوع من الحلول. 


آليات الإدخال الآكثر انتشاراً هي: 


` لوحة الأرقام: 


تحتوي الهواتف المحمولة عادة على لوحة مكونة من 12 رقماً. تعتبر هذه اللوحة بالغة الفعالية لإدخال الأرقام ولكن الأمور تصبح 
أكثر إرباكاً عند الرغبة بإدخال النصوص بسبب تخصيص كل مفتاح لتمثيل ثلاث محارف. بالطبع تم تطوير تقنيات مختلفة لجعل 
عملية الإدخال أكثر سهولة من هذه التقنيات تقنية 19 بحيث تقوم هذه التقنية بتوقع النص المراد إدخاله عند إدخال تتالي معين 
للمخازف: 


- الإدخال باستخدام القلم: 
يُعتبر أحد الإنجازات المميزة ويتمثل في تمكين استخدام شاشات اللمس التي تعتمد على القلم في الإدخال. سمح هذا الأسلوب 
للمستخدمين بعمليات الإدخال لاتحتاج إلى لوحة مفاتيح أوإلى لوحة أرقام فيزيائية. من أكثر التقنيات شيوعاً والمستخدمة في هذا 
المجال: 
ه لوحة المفاتيح الافتراضية: حيث يجري إظهار لوحة مفاتيح على الشاشة ويمكن للمستخدم عندها إدخال المعلومات كأنه 
يعمل على لوحة مفاتيح حقيقية. تكمن المشكلة في هذا الحل في الحاجة إلى مساحة شاشة كبيرة نسبياً وفي محدودية 
سرعة الإدخال. 
التعرف على المحارف: تعمل هذه التقنية على محاولة تفسير المحارف التي تتم كتابتها بواسطة القلم على الشاشة (على 
مساحة محددة هن الشاشة غالبا). يوفر نظام تشغيل 8 sسملصة‏ هذه الميزة وهي تعد فعالة جدا في حال التصوصن 
الصغيرة ولكنها تصبح أقل فعالية في حال الرغبة برفع سرعة الإدخال في النصوص الكبيرة. 
مجموعة محارف :)۴إ : قدمت بعض أنظمة التشغيل الخاصة بالتجهيز ات المحمولة شكلاً جديداً من أشكال التعرف 
على المحارف وذلك باستخدام مجموعة محارف خاصة تدعى 1)؟fة6۲‏ تسمح هذه المحارف بسهولة التعرف على 
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الأحرف» تتطلب هذه المحارف بعض التدريب ولكنها تحقق سرعة جيدة في الإدخال بعد أن يتم التعود عليها. 
ه التعرف المباشر على خط اليد: تعتمد هذه التقنية على إمكانية تدريب نظام التشغيل على التعرف المباشر على خط يد 
المُستخدم. تتطلب هذه العملية» حتى تكون فعالةء برمجيات وعتاد صلب أكثر تعقيدا. 


الإدخال باستخدام لوحة المفاتيح: 
بالرغم من كل التطورات التي قدمت أشكال مختلفة لإدخال البيانات» ما تزال لوحة المفاتيح هي الطريقة الأكثر فعالية لعملية الإدخال. 
يمكن أن تكون لوحة المفاتيح مُدمَجة كما في الحواسب المحمولة أوكطرفية يمكن وصلها إلى الجهاز المحمول. 


الإدخال الصوتي: 
تعتبر عملية الإدخال الصوتي عملية سهلة وذات فعالية كبيرة إذ يمكن تنفيذ بعض الأرامر الصوتية مباشرة كتأسيس اتصال آو البحث 


غن علو مات الاتصال لشخكن ما. 
أما في حالة التطبيقات الأكثر تعقيداً مثل تلك الخاصة بالاستعلام الصوتي أوتنفيذ المناقلات البنكيةء فعادة يمتلك هذا التطبيق الإمكانيات 
الكافية للإجابة على الأسئلة الصوتية المعقدة من النمط: " كيف سيكون الطقس غداً في دمشق" ومن النمط " ما هي الطائرات القادمة من 
دبي إلى دمشق اليوم ". غالباً ما تستخدم هذه التطبيقات المعايير الخاصة بأنظمة الاستجابة الصوتية مثل eXMء1ه۷.‏ 


التجهيزات المحمولة 


(تتمة) 
آلية الاتصال اللاسلكية: 


تتوافر ثلاث أنواع رئيسية لللاتصال اللاسلكي من التجهيزات اللاسلكية: اتصال باستخدام وحدتين» الاتصال باستخدام التجهيزات القابلة 
للفصل» الإتصال المُبيّت ضمن الجهاز . 


الاتصال باستخدام وحدتين: 
يتطلب الاتصال من هذا النوع جهازين للعمل مع بعضهما البعض كجهاز ۲۸ وجهاز هاتف خليوي مثلا. 
توفر أحد هذه التجهيزات الاتصال اللاسلكي للجهاز الآخر ليقوم باستعمالها. 
يمكن أن تتصل هذه التجهيز ات بعضها البعض بالإحدى الطرق التالية: 

- الاتصال المباشر بواسطة كابل 

- الاتصال باستخدام الاشعة تحت الحمراء 

- الاتصال باستخدام تقنية بلوتوث. 
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Using Cable, 
Infrared, or Bluetooth Ezê Mobile Network 


يساعد هذا النمط من الاتصال في اختيار الجهاز المُراد استخدامه اعتماداً على الخدمة التي صمم لأجلها ولا حاجة عندئذ 
للاتضحية بالخدمات مقابل قدرة الاتصال لاسلكياً. 

تساعد هذه الطريقة أيضاً في استبدال الأجهزة القديمة دون الحاجة إلى استبدال النظام بكامله. كما يمكن استخدام جهاز متصل 
لاسلكياأً لتأمين الاتصال اللاسلكي لأكثر من جهاز آخر. 

تتمثل الناحية السيئة في هذا الحل في تعقيده. إذ يجب إعداد كل من الهاتف الخليوي والجهاز المحمول لضمان عمل هذا الحل. 
كما أن عدم توفر الاتصال بتقنية بلوتوث قد يجعل من عملية الاتصال بالأشعة تحت الحمراء أوباستخدام الكابل» عملية معيقة 
بعض الشي ء. 


التجهيزات المحمولة 
(تتمة) 
آلية الاتصال اللاسلكية: 


الاتصال باستخدام التجهيزات القابلة للفصل: 


يتضمن هذا الحل استخدام الوحدات النمطية القابلة للفصل مع الجهاز المحمول لتأمين عملية الاتصال اللاسلكي. يمكن لهذه الوحدات 
تأمين الاتصال لأكثر من نوع من الشبكات للاسلكية بعملية إعداد بسيطة. 

يتطلب استخدام هذه الوحدات توفر قابس خاص لوصل هذه الطرفيات ويكون غالباً .(PCMCI) yi (Compact flash) طaill ja‏ 
تتلخص الميز ة الأكثر أهمية لهذا النوع من الاتصال في إمكانية استخدام وحدات مختلفة لتوفير عملية الربط مع أنواع مختلفة من 
الشبكات ك ...PANyÎ WANyÎ WLAN‏ 


آلية الاتصال المبيتة ضمن الجهاز: 

تعتبر عملية مكاملة أوتضمين الجهاز المحمول آلية الاتصال اللاسلكيةء أحد أساليب الاتصال اللاسلكي المعتمدة. 

يعتبر هذا الخيار أساسي في حال الهواتف المحمولة وقد بدأت التجهيزات المحمولة الأخرى كالحواسب المحمولة مثلاً في اعتماده 
مؤخراً. 

تتلخص الميزة الأساسية في هذه الطريقة في تقليل التعقيد ما أمكن وتأمين تكامل مثالي بين مكون الاتصال اللاسلكي والجهاز المحمول 
ونظام التشغيل الخاص بالجهاز. 

إلا أن فقدان المرونة يُعتبر أحد العناصر السلبية في هذا الحلء حيث يصبح مستخدم الجهاز محدوداً بنمط الشبكة اللاسلكية التي تم 
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مكاملة آلية الأتضال. الخاصة بها ضمن.جهازء 


المعيارية في الحلول المحمولة 


شعرت العديد من الشركات بمشكلة نقص المعايير القياسية كعائق في وجه تطوير الحلول المحمولةء وشعرت هذه الشركات بالقلق من 
تحول التقنيات التي تستخدمها إلى تقنيات غير معيارية حتى قبل أن تبدا بتطوير الحلول الخاصة بها. 


لذلك تم العمل على العديد من المعايير القياسية في مجال الحلول المحمولة كان من أهمها ۷4۴ الخاص بتطوير حلول التطبيقات 
اللاسلكية على الإنترنت حيث قام هذا المعيار بحل الكثير من المشاكل المتعلقة بالعمل بشكل موافق لمعايير الإنترنت. 


كما تم تطوير لغات مختلفة مٿل WML‏ و HTML‏ و اVoiceXM‏ في مجال اللغات التأشيرية الخاصة بالإنترنت» 


وتم استخدام تقنيتين أساسيتين هما تقنية BREW (Binary Runtime Environment for wireless)‏ في مجال الھواتف الذكيةء 
وتقنية [2۷1٤‏ من أجل طيف واسع من التجهيزات المحمولةء وذلك في مجال المعايير الخاصة بتطوير التطبيقات من جهة الزبون. 


وقدمت شركة مايكروسوفت بيئة.(kا NEF). NE1 comp) ؟r2 ew0‏ والتي لا تعتبر قياسية بشكل رسمي ولكنها تكتسب أهمية 
كبيرة كونها فتحت مجال تطوير التطبيقات للتجهيزات العاملة على نظام تشغیل ٤)€-ءd0w١1س.‏ 


ولا بد في هذا السياق من ذكر كون تطبيقات C/C++‏ و هط ua1ء۷1‏ تعتبر خيارات جيدة عند الرغبة بتطوير التطبيقات للطرفيات 
الذكية. 


وجرى تطوير لغة ١١11‏ ر؟ المرشحة لتكون أحد المعايير التي تستخدم لعمليات المُزامنةء إذ تسمح بعملية المزامنة لمعلومات جهات 
الاتضال: وللمواغيد والتانات بين آلجهاز النحمرل وجهاز متضل: 


ولم يجر الاتفاق على معيار خاص بال ۷4١‏ لكن تم مؤخراً دعم بروتوكول 1۴ بالنسبة ل ۷14١‏ وذلك وفق المعايير 
802.114 و802.11 و×802.11ء وتم توفیر تقنية بلوتوث معیاراً للشبكات ۸N‏ . 


تصنيف التجهيزات المحمولة 


تتنو ع التجهيزات المحمولة بشكل كبير» ويصعب تصنيفها بشكل دقيق. فيما يلي أحد التصنيفات المستخدمة لهذه التجيزات: 
الهواتف المحمولة المجهزة بإمكانية الولوج إلى الوب. 
أجهزة الرسائل القصيرة بالاتجاهين: تسمح هذه الأجهزة بإرسال واستقبال الرسائل النصية 
الهو اتف الذكية منخفضة السوية 
PDA‏ 
الهو اتف الذكية عالية السوية 
الحواسب الشخصية اليدوية 
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7- الحواسب المسطحة 
8- الحواسب المحمولة. 
التجارة الالكترونية عن طريق الأجهزة المحمولة 
m-CcCOmMmMeEerCce‏ 


يندرج تحت هذا النوع من التجارة الالكترونية عمليات الشراء لمنتجات أوخدمات باستخدام الأجهزة المحمولةء حيث كانت الفكرة 
الأساسية التي تتعلق بتطوير هذا المفهوم وأدواتهء إعطاء القدرة لمستخدمي التجهيزات المحمولة على إجراء الأعمال وعمليات 
الشراء الالكترونية من أي مكان وفي أي وقت بنفس فعالية الأعمال الالكترونية تجريدها من قيود الاتصال السلكي. 

من أهم التطبيقات لهذا المفهوم والتي يُعتقد أنها ستقود سوق التجارة الالكترونية المحمولة خلال السنوات القادمة هي: 


الشراء الرقمي: يركز هذا النوع من العملية الشرائية على المنتجات الرقمية اتن بسكن تخا وتنك اها فوزا: 
أكبر الأسواق لهذا المنتجات هي أسواق الألعاب الخاصة بالتجهيزات المحمولةء والرنات» والنغمات الخاصة بهذه التجهيزات. 


التعاملات البنكية المحمولة: 
هناك نوعان أساسيان من الخدمات التي يمكن تقديمها فيما يتعلق بالمعاملات البنكية. 
€ الأولى تللك المتعلقة بتمكين الوصول إلى الحساب البنكي للاطلاع على كشف المناقلات» إضافة إلى إمكانية إجراء 
المناقلات البنكية. وتعتبر هذه الخدمة امتداداً للعمليات البنكية باستخدام الانترنت كون التجهيزات المحمولة قد تم تزويدها 
بإمكانية الاتصال بهذه الشبكة. 


© أّما الثانية فهي المتعلقة باستخدام التجهيزات المحمولة في عملية الدفع حيث يتم الدفع عن طريق الجهاز بنقد رقمي يتم 
تحويله إلى نقد حقيقي عن طريق الشركة التي تؤمن الاتصال كما في شركات الهاتف المحمول. 


خدمات المعلومات: 
يتضمن هذا النوع من الخدمات تزويد مستخدمي الأجهزة المحمولة بالمعلومات المتنوعة سواء فيما يختص بحركة سوق الأسهم المالية 
أوأخبار الرياضة» أوالسياسة»ء أوالطقس» حيث يمكن إرسال هذه المعلومات إلى المستخدم كرسائل تنبيهية. 


التجارة الالكترونية عن طريق الأجهزة المحمولة 
mM-CcCOMmMeEerce‏ 


ا 
الخدمات المتعلقة بالموقع: 
يمكن أن تشكل إمكانية تحديد موقع المستخدم واحتياجاته أداة بالغة القوة في خدمات المبيع بحيث يتم تزويد المستخدم بالبيانات الخاصة 
عن المنتج الذي يحتاجه في أقرب مكان بيع فيزيائي إليه. 
لكن ما يز ال بعضن,القلى ساتداً بخصوصن هذا النوع من الخدمات بما يتعلق بخصوصية المستخدم ومعلومات حركته. 


التسوق باستخدام التجهيزات المحمولة: 
لن يكتسب أغلب أنواع التسوق الالكتروني باستخدام التجهيزات المحمولة شعبية في المستقبل القريب بسبب محدودية التجهيزات التي 
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تجعل التسوق بالطرق الأخرى تجربة أكثر تميزا. 
بالرعم من هذا ما تزا يعض الانتخ امات مطارية كما هرالحال في حجز بطاقات اخروض السيهانية قبل ساعة من العركن مقا 
أوفي حالة مقارنة الأسعار المتوفرة على الانترنت لمنتج ما قبل شراءه من متجر فيزيائي. 


الإعلان باستخدام التجهيزات المحمولة: 

يتوفر لدى مقدم الخدمة المحمولة معلومات مختلفة حول جهاز المستخدم وموقعه والبضائع التي يقوم بشراءها وغيرها من المعلومات 
التسويقية. 

يمكن لمزود الخدمة أن يرسل رسائل إعلائية لمنتج أومنتجات إلى المستخدمين بحسب اهتماماتهم ومستوى دخلهم وقدرتهم الشرائية. 
تكمن المشكلة الأساسية في هذا النوع من الإعلانات في أن المستخدم سيقوم بتغيير مزود الخدمة في حال شعر بالإزعاج من عملية 
الإغراق برسائل الإعلان. 

لذا ُتوقع فقط أن نرى نوعاً من الإعلانات المطلوبة من قبل المستخدم كالإعلان عن أقرب محطة وقود أوأقرب صيدلية... وغيرها. 


التجارة الالكترونية عن طريق الأجهزة المحمولة 
mM-CcCOMmMeEerce‏ 


. 


ر 


تقع مسؤولية عدم القبول السريع للتجارة الالكترونية المحمولة على عاتق مجموعة من الأسباب الفنية والأسباب العملياتية المتعلقة 
بالأعمالء من أهمها: 
عدم احتواء أغلب التجهيز ات والشبكات على مزايا خاصة تسمل عمليات استخدام النجهيزات في عمليات الشراء 
عدم توفر واجهات استخدام مناسبة لإدخال البيانات 
عدم توفير الشبكات اللاسلكية لمزودي الخدمات (إلا مؤخراً) لسرعات كافية من أجل التعامل مع المكونات المرتبطة 
بإجراء عمليات الشراء. 
عدم تناسب الصور وحيدة اللون أوالصورة بالتدرجات الرمادية بشكل كبير مع عمليات الشراء. فبالرغم من أن الشركات 
المصنعة للتجهيزات المحمولة قد زودت تجهيزاتها بشاشات ملونة عالية الدقةء إلا أن أغلب التجهيزات المنتشرة لا 
تحتوي هذه الميزة. 
دم اقتناع معظم المستخدمين بأن التجارة الالكترونية (السلكية) غير آمنة لذا فما يزال هناك طريق طويل أمام التجارة 
الالكترونية المحمولة في موضوع الأمان حيث يدخل بالحسبان موضوع أمان إرسال المعلومات عبر الأثير كعامل خطر 
إضافي. 
عدم توفر التطبيقات المناسبة للتجهيزات المحمولة. 
عدم التطرق لسياسات الفوترة والتسعير بين المستهلك ومزود الخدمة من قبل صناعة التجهيزات اللاسلكية. 


تشير الدلائل إلى أن مصير التجارة اللالكترونية المحمولة هوالنجاح ولكن هذا النجاح سيأخذ وقتاً أكثر مما كان متوقعا. 
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القسم الثاني والثالث: 


الشبكات اللاسلكية» أنواعها والتقنيات المستخدمة فيها 


الكلمات المفتاحية: 
مجمو عة» عنصر» المجموعة الخاليةء» مجموعة جزئيةء علاقة انتماءء علاقة احتواء» مخطط فن»› تقاطع»› اجتماع» مجمو عات منفصلة»› 
المجمو عة المتدة: 


ملخضص: 
E a ST‏ 
وعن تقنية الشبكات اللاسلكية التي ستسيطر على السوق. 

نغطي في هذا الجزء من الجلسة الأنواع الأربعة الأساسية للشبكات اللاسلكية ونتعرف على مجموعة من التقنيات المستخدمة في هذه 


أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على: 
€ الشبكة اللاسلكية المحلية الشخصية ( ۲۸۸ )W‏ 
© الشبكة اللاسلكية المحلية (۸اW)‏ 
© الشبكة اللاسلكية العريضة )WW۸١(‏ 


€ شبكة الأقمار الصناعية (ع)11م)ه5S)‏ 
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تعد الشبكات اللاسلكية أحد أكثر المواضيع سخونة في مجال التقنيات المحمولة فالجميع يتحدث عن الجيل الثالث من الشبكات اللاسلكيةء 
وعن تقنية الشبكات اللاسلكية التي ستسيطر على السوق. 


سنغطي في هذا الجزء من الجلسة الأنواع الأربعة الأساسية للشبكات اللاسلكية : 
1- الشبكة اللاسلكية المحلية الشخصية.(۷۲۸۸) 
2- الشبكة اللاسلكية المحلية ( ۸ا )W‏ 
3- الشبكة اللاسلكية العريضة )WWAN(‏ 
4- شبكة الأقمار الصناعية (ع)11عاهS)‏ . 


مقدمة عن الشبكات اللاسلكية 


تخدم الشبكات اللاسلكية العديد من الأغراض. تشكل هذه الشبكات في بعض الأحيان بديلاً عن الوصل باستخدام الكابلات بينما س 
في أحيان أخرى لتأمين تزويد ومشاركة البيانات عن بعد. 
سنقوم بتقسيم الشبكات اللاسلكية إلى نوعين رئيسين: 
- شبكات المدى القصير : ويتناول هذا التصنيف الشبكات التي تغطي مساحة محدودة كما هي الحال بالنسبة لشبكة W۷4١‏ 
التي تغطي بناء» أوتجمّع» أومعمل أوحتى منزل» كما تندرج تحت هذا التصنيف أيضاً الشبكات المحلية الشخصية ۷۲۸۸. 
تعمل هذه الشبكات عادة على ترددات ليست بحاجة إلى الترخيص ويجري حجزها للأغراض الصناعيةء أوالتجارية 
أوالعلميةء أوالطبية. 
تختلف الترددات المتوفرة من بلد لآخر» ولكن أكثر هذه الترددات شيوعاً هو2.4 جيغاهرتز غير المحجوز تقريباً في كل أنحاء 
العالم. كذلك يتم استخدام الترددات 5 جيغاهرتز و40 جيغاهرتز. 


شبكات المدى الطويل: تستخدَم شبكات المدى الطويل عندما لا تستطيع شبكات المدى القصير تلبية الحاجة لامتداد أكبر لتغطية 
الشبكة. 

غالباً ما يُستخدم هذا النوع من الشبكات من قبل الشركات التي تقدم الاتصال اللاسلكي كخدمة. يمتد هذا النوع من الشبكات 
على مساحات واسعة كحال شبكة مدينةء أومحافظة» أوحتى على بلد كامل. 

أكثر أنواع الشبكات اللاسلكية طويلة المدى شيوعا هر W۸۸١‏ 0 أوالشبكة اللاسلكية العريضة. 

أما عند الحاجة إلى اتصال لأسلكي على مستوى عالمي يمكن أن تشكل الشبكات الاسلكية عبر الأقمار الصناعية حلا أمثلياً. 


مقدمة عن الشبكات اللاسلكية 


تتمة) 


إذا فالأنواع الأربعة الأكثر انتشارا للشبكات اللاسلكية كما ذكرنا والتي تغطي تلك الطويلة والقصيرة المدى هي 
PAN, WLAN, WWAN, Satellite‏ وفیما يلي جدول یوضح آھم خصائص ھذہ الشبکات. 
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EE TTA ET EEET T 
بديل عن التوصيل باستخدام‎ 0 
(WPAN) الكابلات في الشبكات عادة حوالي 10 أمتار‎ IrDA, Bluetooth, 802.15 

الشخصية 
802.11a, b, g,‏ 1-54 تعمل كتوسع للشبكة المحلية 


: عادة حوالي 100 متر 
Mbps HIPERLAN/2‏ أوبديل عن الشبكة السلكية : 


عادة تكون التغطية على 
تعمل كتوسع للشبكة المحلية |أمستوى وطني باستخدام أكثر )WW۸١(_‏ 
من حامل 


8 Kbps-2| GSM, TDMA, CDMA, 
Mbps] GPRS, EDGE, WCDMA 


2 2 Kbps- 
)Satellite( Globa1 تعمل كتوسع للشبكة المحلية يم0‎ ls n TDMA, CDMA, FDMA 
: : ps 


إذا فالأنواع الأربعة الأكثر انتشارا للشبكات اللاسلكية كما ذكرنا والتي تغطي تلك الطويلة والقصيرة المدى هي 
PAN, WLAN, WWAN, Satellite‏ وفیما يلي جدول یوضح أھم خصائص هذہ الشبکات. 


أساسيات الترددات الراديوية 


لا يتطلب تطوير التطبيقات معرفة تفصيلية بالعمل الداخلي للشبكات اللاسلكيةء ولكن معرفة معلومات عن آلية العمل يساعد في فهم 
الطريقة التي تتصرف بها التقنيات اللاسلكية المختلفة. 

قبل الغوص في التقنيات اللاسلكية سنبداً بمقدمة عن التردادات الراديوية. 

الترددات الراديوية: 

تنقل العديد من التقنيات اللاسلكية في شبكات 14¥ WAN, WPAN,‏ معلوماتها باستخدام الموجات الراديوية. 

لتنفيذ هذه العملية يجري تحميل البيانات على موجة راديوية نطلق عليها اسم الحامل. ويْطلق على هذه العملية اسم الترنيم 

.)M0d u1 00(‏ هناك العديد من التقنيات المستخدمة في عملية الترنيم لكل منها مزاياه وعيوبه من حيث الفعالية ومتطلبات الطاقة. 


تقنيات الترنيم الشائعة هي التالية: 
- تكنولولجيا الحزمة الضيقة: تقوم أنظمة الحزمة الضيقة بإرسال واستقبال البيانات باستخدام تردد راديوي محدد. تجري 
المحافظة على بقاء التردد المستخدم ضيقاً ما أمكن. يجري تجاوز موضوع التداخل بتشغيل عدة مستخدمين على عدة ترددات 
وتصبح مسؤولية ا المستقبل استبعاد كل الإشارات عدا تلك المُرسلة على الترددات المحددة. لتتمكن شركة ما من 
استخدام تقنية الحزمة الضيقة يجب أن تحصل على تصريح حكومي لحجز التردد. 
تكنولوجيا الحزمة المنتشرة : تقوم هذه التقنية في تصميمها بمقايضة بين فعالية عرض الحزمة من جهة والموثوقيةء 
والاعتمادية والأمان من جهة أخرى. فهي تستهلك عرض حزمة أكبر من تللك المعتمدة على حزمة تردد ضيقة ولكنها تولد 
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إشارة أقوى وأسهل اكتشافاً من قبل المُستقبلات التي تعرف المؤشرات الخاصة بالإشارة المرسلة. 
تبدوالإشارة التي تستخدم تكنولوجية الحزمة المنتشرة كضجيج بالنسبة لكل المستقبلات عدا المستقبلات التي اُرسلت إليها تلك 
الإشارة. 


أساسيات الترددات الراديوية 


هناك شكلان لهذه التقنية يمكن استخدامهماء هما تقنية قفزات التردد وتقنية التتالي المباشر 
تقنية قفزات التردد ۴155S‏ : تستخدم هذه التقنية حامل ضيق الحزمة يقوم بالدوران بصورة سريعة على الترددات. 

يعلم كل من المرسل والمستقبل في هذه التقنية بتشكيل الترددات المستخدمة. 

الفكرة هي أنه حتى لوتم اعتراض تردد ماء تظل الترددات الأخرى متوفرة للإرسال وإلا فتتم إعادة عملية إرسال البيانات. 
النتيجة تكون في نقل المعلومات بواسطة قناة منطقية وحيدة. 

أما بالنسبة للمستقبلات التي لا تملك تشكيل الترددات المستخدمة يبدوالإرسال وكأنه دفقات قصيرة من الضجيج. 

الحد الأقصى لمعدل الإرسال باستخدام ۴۲855 هو بحدود psط1Mb‏ 


تقنية التتالي المباشر 8S؟5:‏ 

تقوم هذه التقنية بنشر الإشارة على حزمة واسعة من الترددات الراديوية بصورة متوازية. لكل (بت) يتم إرساله هناك (بت) مكرر 
يسمى الرأقاقة. 

كلما ازداد طول هذه الرقاقة كلما كان بالإمكان معالجة واستعادة البيانات في حال تضررها. 

تتطلب اليتات الطويلة أيضاً عرض حزمة أعلى. 

بالنسبة للمستقبلين الذين لا يتوقعون تلقي الإشارة فإن الإشارة المُرسلة بتقنية 0858 تبدوكضجيج ضعيف عريض الحزمة يجري 
رفضه. 


تتطلب 888( طاقة أكبر من ۴88 ولكن يمكن رفع معدل الإرسال إلى قيمة أقصاها sما2M.‏ 


أساسيات الترددات الراديوية 
تقنية المُضاعفة بتقسيم التردد المتعامد (0۴00) 


يتم في هذه الطريقة إرسال المعلومات بطريقة متوازية بشكل معاكس لتقنية القفز المستخدمة في ۴188ء والانتشار المستخدمة في 
.DSSS‏ 


يمكن من خلال هذه التقنية إرسال كمية أعلى من البيانات عبر عرض حزمة أضيق» مما يجعل التقنية 0۴0M‏ مناسبة لإرسال 
البيانات بمعدل إرسال عالي. 
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تكمن المشكلة في هذه التقنية في أنها صعبة التطبيق وتتطلب طاقة أعلى من كلا التقنیتین ۴۲585 و5888. 


الشبكات اللاسلكية الشخصية 
WPAN‏ 


دفع الاستخدام المتزايد للتجهيزات الالكترونية في المنازل والمكاتب إلى المزيد من الحاجة إلى اتصال هذه التجهيزات ببعضها 
البعض بأكبر قدر من المرونة. وكان لا بد من التركيز على تطوير شبكات لتخديم عملية ربط هذه التجهيزات. 


من أبرز الأمظة عن هذه التجهيزات: الحواسب الشخصيةء والحواسب المحمولةء والهواتف النقالةء والطابعات» والكثير من 
التجهيز ات الأخرى. 


كانت فكرة ربط تللك التجهيزات بواسطة كابلات مباشرة عملية مزعجة وازدادات الأمور تعقيدا حين تم إضافة المحمولية إلى لك 
التجهيزات. 


ظهرت الشبكات اللاسلكية الشخصية كاستجابة لتلك الحاجة وكانت أبرز الخصائص التي ميزت الشبكات ۷۲۸١‏ هي: 
الاتصال قصير المدى 
الاستهلاك القليل للطاقة 
الكلفة المنخفضة 
شبكات شخصية صغيرة تؤمن الاتصال ضمن مساحة العمل الشخصية. 


المعايير القياسية المستخدمة قي شبکات 
WPAN‏ 


استّخدمت العديد من المعايير القياسية للشبكات اللاسلكية الشخصيةء بحيث امتلك كل منها نقاط قوة ونقاط ضعف. 


سنستعرض في هذا الجزء من الجلسة بعض هذه المعايير وأغراض استخدامها: 


معیار 1۲5۸: 
يعود هذا الاختصار إلى المؤسسة العالمية التي قامت بوضع معايير الاتصال التبادلي منخفض الكلفة باستخدام الأشعة تحت الحمراء. 
وضع المعيار 1۲04 مجموعة من البروتوكولات لدعم التجهيزات» والحواسب» وأجهزة الاتصال. 

كان الغرض من هذه البروتوكولات توفير نقل بيانات لاسلكي من نقطة إلى نقطة عبر خط نظر ولمسافة قصيرة وبسرعة عالية. 
تستخدم برتوکو لات 1۲5۸ ال5۸۲۸ 1۲0۸ کالیة تسلیم للمعلومات وال DA CONTROL‏ کالیة تحکم. 

يكمن الغرض الأساسي من 1۲04 في تقديم بديل عن الوصل بالكابل. إذ يكفي بكل بساطة مقابلة بوابات الأشعة تحت الحمراء لجهازين 
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للتمكن من إرسال واستقبال البيانات بينهما. وفيما يلي بعض أهم الخصائص هذا النوع من الاتصال: 
- يصل مجال الاتصال حتى 1 متر وإن كان بالإمكان في بعض الأحيان الوصول حتى 2 متر 
- تقدم هذه التقنية خياراً لتوفير الطاقة في حالات الاتصال ضمن مجال حتى 20 سنتيمتر. حيث يتطلب هذا الخيار طاقة أقل 
بعشر أضعاف من حالة الاستثمار بالطاقة القصوى. 
الاتصال ثنائي الاتجاه. 
سرعة إرسال البيانات تتراوح بين sمط‏ 9600 وحتى Mbps‏ 4. 
تكون التقنية منخفضة الكلفة حيث يمكن تضمين هذه التقنية ضمن جهاز بكلفة لا تتجاوز دولاراً واحداً. 


ولكن» بالرغم مما يقدمه هذا المعيار من ميزات» تبقى هناك الكثير من العوائق التي لا تمكن هذه التقنية من تغطية معظم احتياجات 
الاتصالات الشخصية. 

فمن الممكن أن تكون فكرة استخدام الأشعة تحت الحمراء مناسبة في حالة تبادل معلومات اتصال ما بين شخصين يحملان جهازين 
محمولين» ولكن الأمور تصبح أكثر تعقيداً عند الحاجة إلى الاتصال بطابعة مثلاء والتي قد لا نستطيع الحصول على خط نظر مباشر 
بينها وبين التجهيزات التي تحاول الاتصال بها في بيئة مكتب أوفي البيئة المنزلية. 


المعايير القياسية المستخدمة ئ شبکات 
WPAN‏ 


lئnعيlر BlueTooth‏ 
بلوتوث هومعيار يساعد في الاتصال اللاسلكي بين الحواسب المحمولةء والهواتف النقالةء وبعض التجهيزات المحمولة الأخرى. 


بصورة مغايرة لما لحظناه في حالة الأشعة تحت الحمراءء لا تتطلب التجهيزات المزودة بتقنية بلوتوث خط نظر بين التجهيزات 
المتصلةء وتستتطيع تأمين الاتصال عبر الحواجز. 


تكون مسافة الاتصال في الحالة العادية 10 متر ولكن يمكن الوصول حتى 100 متر باستخدام مضخمات إشارة. 


قفد ار ارقت اط 4-6082 2 غير الط رخص الاتضل كا يفك مکل فن بص ى و7206 رمن الكرق ف 
المستقبل القريب أن يتم رفع معدل النقل ليصل إلى كمط10۷1. 


تم تطویر هذا المعیار من قبل شرکات کبری حیث بدأت بھ شرکة 1۸٥ءوءاا8›‏ ثم تعاونت معھا شرکات مٿJ »INTEL>»Nokia‏ 
r osh¡iba‏ و BM‏ لتشكل ما يسمى ب 816؟› 

Microsoft , Motorola, Jn ثم انضمت العديد من هذه الشركات إلى هذه المجموعة‎ )Bاuetooth‎ Special Interest group) 
وأكثر من ألفي شركة أخرى.‎ Lucent , 30M 


تبقى التوقعات المرتبطة بهذا المعيار كبيرة» ولكن بلوتوث ما يزال حتى الآن يعمل وبشكل أساسي كبديل عن الاتصال بالكابل. 
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يقدم بلوتوث آلية اكتشاف تلقائي حيث يمكن للتجهيزات المزودة بهذه التقنية اكتشاف جميع الأجهزة الواقعة ضمن مجال عملهاء بحيث 
يجري بعدها تأسيس الاتصال بين تلك الأجهزة. 


هناك بعض التخوف من التحميل الزائد للطيف 2.46117 مع استخدام المزيد من التجهيزات التي التي تستعمل نقنية بلوتوث. لتجاوز 
هذه المشكلة تعرّف محددات المعيار بلوتوث ثلاث أنماط للتجهيزات: 


التجهيزات القابلة للاحتشاف بشكل عام : يسمح هذا النمط بأن يتم اكتشاف الجهاز الذي يستخدم هذه التقنية من أي جهاز آخر ضمن 
المجال. 


التجهيزات القابلة للاكتشاف بشكل محدود: يمكن فقط لتجهيزات محددة وف فة مسقا أن تكتشف مها البعض»› بُستخدم هذا النمط 


بصورة أساسية عند وجود مجموعة من تجهيزات بلوتوث التي نرغب أن تتعرف على بعضها البعض أتوماتيكياً. 
التجهيزات غير القابلة للاكتشاف: يجعل هذا النمط الجهاز غير مرئي وغير قابل للاكتشاف من قبل التجهيزات الأخرى. 
المعابير القياسية المستخدمة في شبات 
WPAN‏ 


BlueTooth رlيعnئl‎ 


ما أن يتم الاتصال بين جهازين باستخدام بلوتوث يتم تشكيل شبكة ۴1۳0/٤1‏ يمكن أن تتألف من 8 أجهزة على الأكثر بحيث 
يمكن لأي من تلك الأجهزة الاتصال مباشرة مع الآخر. 


لتاليف شبكة مكونة من أكثر من ثمان أجهزة لا بد من استخدام آكثر من ٥1۳0۷٤1‏ تدمج مع بعضها بما يسمى الشبكة المبعثرة 
بحيث لا يمكن لجميع التجهيزات في الشبكة التخاطب وإنما فقط تلك الموجودة في كل 6١٠ء۴1‏ تستطيع التخاطب مع التجهيزات 
الموجودة في نفس ال اع0ع1". 


في الشكل التالي يوجد شبكة مبعثرة واحدة مؤلفة من خمس اع٣0ء¡۲‏ 
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ما أن يتم الاتصال بين جهازين باستخدام بلوتوث يتم تشكيل شبكة ۴1۳0/٤1‏ يمكن أن تتألف من 8 أجهزة على الأكثر بحيث 
يمكن لأي من تلك الأجهزة الاتصال مباشرة مع الآخر. 


لتأليف شبكة مكونة من أكثر من ثمان أجهزة لا بد من استخدام أكثر من 1۳0١٤‏ تدمج مع بعضها بما يسمى الشبكة المبعثرة 
بحيث لا يمكن لجميع التجهيزات في الشبكة التخاطب وإنما فقط تلك الموجودة في كل ٥١٥ء۴1‏ تستطيع التخاطب مع التجھيزات 


الموجودة في نفس ال اع١0ع1".‏ 


المعايير القياسية المستخدمة في شبكات 
WPAN‏ 
lئhعيlر BlueTooth‏ 
التشكيلات الخاصۂ بالمعیار 1٥0٤1‏ ueں[|8‏ 
عند تطوير المعيار الخاص ببلوتوث ولضمان التعامل بين التجهيزات التي تزود هذه التقنية قامت 516 بتحديد مجموعة من التشكيلات 
عددها 13 لضمان العمل المشترك لهذه التجهيزات وفق أساس واحد. 
تم تصميم كل تشكيل ليقوم بأداء مهمة محددة. 
تم تصميم أربعة تشكيلات رئيسية لتكون اللبنات الأساسية التي ستعتمد عليها التشكيلات الأخرى. 
التشكيلات التسعة الباقية هي تشكيلات الاستخدام وتعبر كل منها عن شكل من أشكال العمليات التي يمكن إجراءها بواسطة هذه التقنية. 
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لم يتم تصميم التشكيلات المذكورة لتحديد طريقة واحدة لاستخدام تقنية بلوتوث ولكنها صممت فقط كمعيار قياسي لضمان عمل 
التجهيزات مع بعضها البعض أي يمكن لأي مصنع تقديم الآليات التي يرغب بها على أن تكون مؤسسة على هذا المعيار لضمان عمل 
المتبادل للجهاز مع الأجهزة الأخرى التي تستخدم تقنية بلوتوث. 

لمزيد من المعلومات حول هذه التشكيلات يمكن زيارة الموقع 1.c01٤0٥luetاwww.b.‏ 


الأمان في المعیار ۲٣۵٤‏ eںBl:‏ 

لما كانت أحد أولويات تقنية بلوتوث أن تكون بديلاً عن استخدام الكابلات فلا بد لها أن تقدم سوية أمان مساوية على الأقل لما هومتوفر 
في حالة الكابلات. 

تحدد خصائص الأمان في تقنية بلوتوث في طبقة الربط (من طبقات 051). أما على مستوى التطبيق فلم يتم تحديد أية آلية حيث تم 
ترك هذه السوية للمطور لتحديد الآلية الأنسب حسب التطبيق المستخدم. 

يمكن للاتصال باستخدام بلوتوث أن يكون مشفراً كذلك يقدم آلية تحقق مبيتة ضمن الجهاز. 

يمكن أن يحدد المستخدم درجة التشفير ويمكن أن يستخدم مفتاح بطول يتراوح بين 8 إلى 128 بيت. 

يمكن هذا المستخدم وحسب درجة الأمان المطلوبة تحديد التوازن الأفضل بين سرعة الاتصال ومستوى الأمان. 


المعايير القياسية المستخدمة في شبكات 
WPAN‏ 
المعيار 802.15 


المعيار 802.15: 
هومجمو عة من الخصائص التي حددها معهد )1۴٤٤(‏ لتطوير المعايير للشبكات اللاسلكية قصيرة المدى أوالشبكات اللاساكية 


عند البدء بوضع هذا المعيار تمت الاستفادة من المواصفات المُستخدمة في تقنية بلوتوث واستخدام جزء منها كأساس لمعيار 802.15. 


يهدف هذا المعيار بصورة أساسية إلى تقييس التحكم بالوصول إلى الوسط (©4€) كذلك الطبقة الفيزيائية من تقنية بلوتوث ويتطرق 
إلى مواضيع مثل التعامل المتبادل على الشبكة. لهذا الغرض جرى إنشاء أربع مجموعات مهام للعمل على المكونات المختلفة لهذا 
هي : 
مجمg‏ عة WPAN/Blue Tooth pla‏ 
مجم عة Coexistence Mechanisms pl‏ 
مجموعة مهام W۲4١‏ عالي المعدل 
مجموعة مهام 0۴۸١‏ منخفض المعدل - بعمر بطارية طويل. 
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الشبكات اللاسلكية المحلية 
WLAN‏ 


تعد حلول الشبكات اللاسلكية المحلية من أكثر القطاعات سرعة في التطور في مجال صناعة الاتصالات. 


أهم استخدامات هذه الشبكات كانت توفير الكلف وتجنب مد الكابلات بالإضافة إلى تقديم اتصال انترنت بسرعة عالية للمستخدمين. 
وما تزال الكثير من الاستخدامات الهامة لهذه الشبكات تظهر كل يوم. 


عند تطوير تجهيزات هذا النوع من الشبكات كان لا بد من تحديد مجموعة من المُحددات الأساسيات التي تشمل: 
التغطية : عادة ما تغطي هذه التجهيزات مساحة بنصف قطر يتراوح بين 50 و150 متراً. 
سرعة نقل البيانات: من 1 كماM‏ إلى Mbps‏ 54 
التداخل: يجب دراسة التداخل مع شبكات من أنواع أخرى. 
استهلاك الطاقة: يختلف استهلاك الطاقة من قبل موائمات الشبكة اللاسلكية بحسب المعيار الذي تستخدمه. 
السعر: يرتبط بالمتطلبات والمعيار المستخدم. 


ترتیب شبکات ۷AN‏ 
يتدرج ترتيب شبكات ¥14 من تلك البسيطة جدأً حتى شديدة التعقيد. 
أبسط شكل لترتيب هذه الشبكات هونمط النظير إلى النظير حيث يمكن في هذا الترتيب اتصال موائمي شبكة أوأكثر ببعضهما 


البعض. عادة ما يسمى هذا الترتيب بالاتصال الخاص (٥٥ط‏ 4ه). لا يتطلب هذا الترتيب وجود نقطة ولوج لاسلكية حيث يتم 


الاتصال بصورة مباشرة ودون الحاجة إلى المرور بعقدة مركزية أي لا يتطلب إدارة أوإعداد مسبق. 


الترتيب الخاص (c٤٥ط )۸d‏ 


أما الترتيب البنيوي المؤلف من نقطة ولوج لاسلكية الاتصال بالشبكة السلكيةء فيؤمنء» بالإضافة -إلى ميزة مُشاركة عدة تجهيزات 
متصلة مع نقطة ولوج لاسلكية- اتصالا سريعاً وواسعاً مرتبطاً بهذه النقطة. 
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يفضتل في هذا الترتيب أن تكون مساحات تغطية نقاط الولو ج متقاطعة لتأمين استمرارية في الاتصال دون أي انقطاع على الحدود 
بين مساحات التغطية. يمكن في هذا النوع من الترتيب استخدام تجهيزات نقاط التوسيع (وهي عبارة عن مقويات إشارة تقوم فقط 

بتلقي الإشارة وإعادة بثها) التي لا تتطلب الاتصال السلكي بالشبكةء لذلك ن لتوسيع الشبكة للاسلكية في المناطق البعيدة نسبياً. 
ويعتبر استخدام الهوائيات الموجهة» والتي تسمح بإرسال الإشارة باتجاه محدد لاستقبالها اعتماداً على هوائي مقابل بهدف إيصال 

الإشارة إلى نقطة ولوج أخرىء» أحد أساليب توسيع امتداد الشبكة أيضا. 


Wired SEVE 


#icoess Point 


Access Poiil 


الترتيب البنيوي 


WLAN تlكبٹ معايیر‎ 


تبنت العديد من الهيئات الواضعة للمعايير وضع معايير خاصة بشبكات ۷1_۸۸ من أھم هذہ الھیئات 1٤٤٤‏ و1؟E1‏ وقام بالتسویق 
لهذه المعايير الڻتھاد HomeRF‏ 
هناك ثلاث معايير أساسية تستحق الاهتمام الأكبر : 


المعيار 802.11: 

يعد أول معيار تم تعريفه لشبكات ۰۷14١‏ يستخدم هذا المعيار نفس البروتوكو لات الخاصة بالتبديل والمُستخدمة في شبكات 
Ether‏ السلكية. ولكنه يسمح بالاتصال اللاسلكي باستخدام التردد الراديوي zط2.46‏ 

يدعم هذا المعيار تقنيتي التعدیل ۴۲188 و؟S؟05S.‏ 

لم تعد التجهيزات الخاصة بهذا المعيار منتشرة بشكل كبير نتيجة حلول المنتجات التي تدعم المعايير 802.114 وط802.11 بدلا عنها. 


802.11b/Wi-Fi المعيار‎ 

يعد هذا المعيار من أكثر المعايير انتشاراً في عائلة ×802.11. يستخدم هذا المعيار الآلية 0888 باستخدام الطيف 2.4612. يمكن 
للمعيار 802.11 أن يصل إلى السرعة sمط‏ 11۷ ولمسافة تصل إلى 100 متر. 

هناك مقايضة تتم بين المسافة ومعدل النقل وتتدرج من كمط 1۷ لمسافة 100 متر إلى sصط 11M‏ لمسافة 30 متر. 


قام اتحاد )۷٤E٣۸4(‏ بإعداد شهادة باسم W1۴1‏ تتضمن إمكانية عمل منتج ما يعمل باستخدام المعيار ا802.11 مع منتج آخر حاصل 
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WLÛLAN تlكبشٹ معايیر‎ 


المعيار 802.114: 
يعد المعيار 802.114 بديلاً يوفر سرعة أكبر من 802.115 ويستخدم التردد 567 وبسرعة تصل حتى كا۷ 54. 
بعكس المعيار 802.11 وط802.11ء يستخدم المعيار 802.114 الترنیم من نوع 0۴5. 


إن استخدام تردد مختلف وآلية ترنيم مخنلفة يؤدي إلى عدم توافق شبكات المعيار 802.114 مع شبكات المعيار طا802.11. 


حمل هذا المعيار العديد من الميزات منها رفع سرعة نقل البيانات 54م والتقليل من التداخل نظراً لاستخدام تردد أقل ازدحاماً. 
ولكن في نفس الوقت انخفض المجال الأقصى الذي تغطيه نقطة الولوج من 100 متر في حالة المعيار ا802.11 إلى 50 أوحتى 25 
متر في حالة المعيار 802.114. 


كما يبرز أيضاً الفرق في استهلاك الطاقة بين المعيارين فالمعيار 802.11 يستخدم كما ذكرنا تقنية 0۴5١‏ والتي تستهلك طاقة أكبر 
من التقنية 0888 المُعتمدة في المعيار ط802.11. 


معاییر شبکات WLAN‏ 
المعيار ع802.11: 
يقدم هذا المعيار الاتصال اللاسلكي بسرعة عالية على التردد 2.467 مع المحافظة على التوافقية مع المعيار ط802.11. 
يتم الوصول إلى هذه الميزات عن طريق طبقتين الأولى تعتمد المعيار ع802.11 تعمل على التردد 2.4617 المستخدم في المعيار 
0 وباستخدام نفس نوع التعديل 0888 حيث يمكن الحصول على سرعة تصل حتى psط11M.‏ 
أما الطبقة الثانية فتعتمد تعديل أكثر فعالية هر 0۴0M‏ باستخدام نفس التردد 2.4۷117 للوصول إلى معدل نقل للبيانات كمط54۷. 


عمليا تستطيع بطاقات الشبكة ونقاط الولوج العاملة باستخدام المعيار 802.11 العمل مع بطاقات الشبكة ونقاط الولوج العاملة باستخدام 
المعيار 802.11 لكن سيُخفض أي مكون يعمل بالمعيار 802.116 معدل نقل البيانات إلى قيمة أقصاها sمط111.‏ لذا يجب أن تكون 
المكونات جميعها عاملة على المعيار 802.11 للوصول إلى سرعة كمط54۷. 

تتشابه النواحي الأخرى مثل تلك الخاصة بمساحة التغطية للشبكة بين المعيارين ا802.11 وع802.11. 


معايير 802.11 الأخرى: 

حددت 15٤۴٤‏ مجموعة من المعايير الأخرى الخاصة بإجراءات مختلفة أهمها: 

المعیار .802.116 E٤۴‏ المخصص لتأمين محددات جودة الخدمة اللازمة لتأمين الحصول على اتصالات صوتية ذات اعتمادية على 
الأنظمة المتوافقة مع ا802.11. 

المعيار .802.11۴ المخصص لتطوير بروتوكول الولوج المتبادل بين نقاط الولو ج. 

المعيار .ا802.11 المخصص لتحسين الطبقة الفيزيائية السريعة الخاصة بالمعيار 802.11a‏ العامل على التردد 56z‏ لجعل 
تجهيزات المعيار 802.114 تخضع لمتطلبات الأنظمة الأوروبية. 
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المعيار 802.111 المخصص لتحسين الطبقة M۸٣‏ للمعيار 802.11 وذلك لزيادة السرية وتحسين آليات التحقق من الهوية. 
معايیر شبكlت WLAN‏ 


:HomeRF رlيsم‎ 

كما يوحي اسم هذا المعيار فهوخاص بالشبكات المحلية اللاسكية الخاصة بالتطبيقات المنزلية. 

تم تأسيس هذا المعيار على المعيار 802.11 باستخدام ۴۲158 ولكن تم القيام ببعض التعديلات لتغطية احتياجات أغلب المستهلكين. 
يستخدم هذا المعيار البرتوكول )Shared Wireless Access *إ0١٤0ء01( ؟SW A۲‏ الذي يدعم الاتصال الصوتي بجودة عالية مع دعم 
للمعيار الخاص بالهو اتف اللاسلكية 08٣1‏ ويسمح باستخدام البنية التحتية اللاسلكية للهاتف وللاتصال الشبكي مع تأمين عدد من 
الميزات الهاتفية المتقدمة متل انتظار المكالمات وتحويلها إضافة إلى تخصيص الرنات...إلخ. 

تم التركيز في هذا المعيار على عامل السعر أكثر من سرعة النقل حيث يمكن لشبكات هذا المعيار تغطية حتى 50 متراً والوصول إلى 
سرعة أقصاها sمطا10M.‏ 

يستخدم هذا المعيار أيضاً التردد zط2.46.‏ 


:HIPERLAN/2, HIPERLAN/1 رlيعnلl‎ 

طرح معهد المعايير الأوروبي للاتصالات )٤1581‏ المعیار ۴٤R۸ 1-4۸٩۸‏ ]1 أي الشبكة المحلية الرادوية عالية الأداء. 

تم طرح نسختين من هذا المعيار الأولى اعتمدت الأولى التردد 5617 ولكنها لم تصل إلى حيز التطبيق ولم يتم إنتاج أي تجهيزات 
تحت هذه النسخة. أما النسخة الثانية من هذا المعيار فهي أيضاً تستخدم التردد 561 ولكن باستخدام التعدیل 0۴5M‏ حيث يمكن 
للتجهيزات وفق هذا المعيار تغطية مسافة بطول 150 متراً وبسرعة أقصاها كمط54» كما ركز هذا المعيار على تحسين جودة 
الخدمة للاتصالات متعدد الوسائط وعمل على تحسين استهلاك الطاقة للتجهيزات المحمولة التي تعتمد هذا المعيار. 

لم يُطبَّق هذا المعيار حتى الآن في التجهيزات ولكنه يعتبر أحد المعايير التي سيكون لها دور كبير في المستقبل القريب. 


شبكات الأقمار الصناعية 
تم التفكير في أنظمة الأقمار الصناعية للاتصال اللاسلكي للصوت والبيانات في بداية التسعينات حيث كان الهدف تقديم شبكة ذات تغطية 


كبيرة تشمل مجموعة من البلدان أوحتى الكوكب بأكمله دون الحاجة إلى أكثر من هاتف نقال أوعمليات الانتقال من نقطة ولوج إلى 


آخری. 


لم تكن معايير ۷0W 4١‏ في هذه المرحلة واضحة وكان أغلب هذه الشبكات تماثلياء وكان من الواضح أن الهو اتف النقالة المعتمدة 
على الأقمار الصناعية ستصبح حقيقة تفرض نفسها كمعيار للاتصال ضمن مساحات واسعة. 


لعب عنصر السعر دورا كبيراً في الحد من انتشار الهواتف المعتمدة على الأقمار الصناعية بسبب توفر الحل الأقل كلفة والمتمثل في 
الهواتف الخليوية. رغم هذا أثبت العديد من تطبيقات شبكات الأقمار الصناعية فعالية في الحالات التالية: 


- في المواقع الثابتة : عندما تكون هناك ضرورة للاتصال اللاسلكي من موقع ليس مُخذما بأي نوع آخر من الشبكات كما هي 


Universal Knowledge Solutions s.a.1 
23 


الحال في شركات النفط والغاز التي تتوضع مقرات عملها في أماكن بعيدة معزولة. 

الاتصالات المحمولة : حيث يمكن للأشخاص الاتصال صوتياً أوإرسال البيانات بغض النظر عن موقعهم كما في حالة فرق 
الإنقاذء الأبحاثءوالقوى العسكرية. 

العربات : وهي أحد أهم الحالات التي يمكن الاستفادة فيها من الاتصال باستخدام الأقمار الصناعية حيث يمكن للعاملين في 
مجال الأخبار والتوصيل الاستفادة من هذا النوع من الاتصال لضمان الاتصال بغض النظر عن موقعهم. 


سرعة نقل البيانات لهذا النوع من الاتصال الشبكي بين كمط2.4K‏ و كمط21 وذلك بحسب الحل المستخدم. 


الشبكات اللاسلكية العريضة 
WWAN‏ 


تم استعمال هذا النوع من الشبكات لأول مرة في بداية الثمانينات حيث كان استخدام هذه الخدمة يتطلب التسجيل على الخدمة وتسديد 
مبلغ يتحدد بالدقائق التي تم استخدام هذه الشبكة خلالها أومؤخراً كمية البيانات التي تم نقلها عبر هذه الشبكة. 

لا تعمل شبكات 0۷4١‏ وبعكس شبكات ۷۴4١‏ و١4[‏ على ترددات غير مرخصة أي أنه يتوجب تسديد مبلغ مالي لحجز 
تردد ما. 

فيما يلي سنستعرض بعض الأفكار الضرورية لفهم عمل الأنواع المختلفة لشبكات .۷W4١N‏ 


الإشارات التماثلية والإشارات الرقمية: 

الإشارة التماثلية : يمتل عادة هذا النوع من الإشارات بموجة جيبية. 

استخدم هذا النوع من الإشارات في الجيل الأول من الشبكات اللاسلكية العريضة وذلك للاتصالات الصوتية. 

الإشارة الرقمية : وهي عبارة عن سلسلة من القيم 0 و1 التي يتم إرسالها وذلك للوصول إلى أقرب صيغة يمكن للحاسب التعامل معها 
وهي التنسيق الٿنائي. 

تم استخدام هذا النوع من الإشارات في شبكات الجيل الثاني اللاسلكية. 

تعتبر الإشارات الرقمية أكثر فعالية وأماناً إضافة إلى تأمين جودة أعلى والعديد من المميزات الأخرى. 


مبدلات الدارة ومبدلات الحزم: 
هناك طريقتان أساسيتان تم اعتمادهما لعملية التبديل 


مبدلات الدارة : تقوم الشبكات التي تعتمد هذا النوع من التبديل بتأسيس اتصال فيزيائي بين طرفين» حيث يستمر حجز دارة لهذا 
الاتصال مع عدم إمكانية استخدام هذه الدارة لتخديم أي اتصال آخر حتى انتهاء الاتصال الأول. 

مشكلة هذا النوع من المبدلات الحاجة إلى عدد دارات مساولعدد الاتصالات المراد تأسيسها. 

مبدلات الحزم:تعمل مبدلات الدارة بشكل جيد حين تكون كمية البيانات التي يتم إرسالها تابتة كما هي الحال في الاتصالات الصوتية 
ولكنها تصبح غير فعالة في العديد من أنواع الاتصالات المخصصة لنقل البيانات» حيث يتم طلب المعلومات بدفقات كما هي الحال في 


استعراض صفحات الانترنت. 
في هذه التقنية يمكن لأكثر من مستخدم الاشتراك في نفس الاتصال مما يساعد على الاستثمار الأمثلي للاتصال. 
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تتم هذه العملية بتقسيم البيانات إلى أجزاء تدعى حزم وإرسالها مرفقة بعنوان المرسل إليهء حيث تتم إعادة توجيهها عبر الاتصالات 
المختلفة حتى الوصول إلى هدفها. 


الشبكات اللاسلكية العريضة 
WWAN‏ 


تم تصنيف الشبكات اللاسلكية العريضة حسب تطورها إلى أربع مراحل هي الجيل الأول» الجيل الثانيءالجيل الثاني والنصف والجيل 
الثالت 


شبكات الجيل الأول 16: 
ظهر هذا النوع من الشبكات في نهاية السبعينات وبداية التمانينات.غالباً ما استخدمت شبكات هذا الجيل في الاتصالات الصوتية. 
كان من أهم العيوب لهذه الشبكات جودة الاتصال المنخفضة والتداخلات المستمرة 


شبكات الجيل الثاني 26: 
استخدمت شبكات الجيل الثاني التقنية الرقمية التي ساعدت بشكل كبير في تقديم اتصالات صوتية بجودة عالية إضافة إلى خدمات 
البيانات الأساسية. 
سمحت هذه الشبكات لعدد أكبر من المستخدمين بالاتصال على نفس مجال الحزمة وبالتالي رفع كفاءة الشبكة بصورة عامة إضافة إلى 
رفع سوية الأمان على الشبكة. 
تدعم معظم شبكات الجيل الثاني نقل البيانات 
أهم شبكات الجيل الثاني المستخدمة حاليا: 
58 (خدمة الهواتف المحمولة المتقدمة وتسمى أحياناً ب ۷۸ ۲5). 
(M4۸ 8-5‏ أوما يسمى بشبكات الوصول المتعدد بالتقسيم حسب الشفرة المستخدمة. 
۷M‏ (النظام العام للاتصالات المحمولة) ويعد من الأنظمة الأكثر شيوعا. 
۴٣‏ (الخليوي الشخصي الرقمي) المستخدم بشكل واسع في اليابان. 


شبكات الجيل الثاني والنصف (2.56) 

كان هذا الجيل خطوة إضافية باتجاه شبكات الجيل الثالث. من أبرز ما ميز هذا الجيل من الشبكات التحول من استخدام مبدلات الدارة 
إلى التبديل بالحزمة مما مكن الوصول إلى سرعة ما144۸ أي ما يتجاوز عشرة أضعاف ما هي عليه في شبكات الجيل الثاني. 
من أهم الشبكات في هذا الجيل : 

CDMA 2000 1× شبكة‎ 

GPR§8 شبکة‎ 

شبكات الجيل الثالث: 

بدأ تطوير شبكات الجيل الثالث ضمن رؤية لتوحيد المعيار المستخدم لهذه الشبكات في جميع البلدان» ونظراً لاعتماد الكثير من البلدان 
تقنيات مختلفة وللمحافظة على التوافقية مع الأنظمة الأقدم ظهر أنه من شبه المستحيل الوصول إلى معيار يغطي هذه الأنواع كلها. 


لذلك تم الاعتماد على ثلاث فروع أساسية لأنظمة شبكات الجيل الثالث وهي EDGE «CDM۸A2000 «YCDMA‏ 
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القسم الرابع: 


بان اتقات اتمخواة وة لتر ا 
الكلمات المفتاحية: 
محمول» لاسلکي»› تقنية» تجهيزات»› تطبيق› تراسل 


ملخضص: 


تعتمد التطبيقات المحمولة عدة أنماط من البنيانء سنحاول في هذه الجلسة تغطية أهم هذه الأنماط التطبيقات المحمولةء ونقاط القوة 


والضعف في كل منها إضافة إلى أمثلة عن التطبيقات التي تعتمد هذه الأنماط. 


أهداف تعليمية: 
يتعرف الطالب في هذا الفصل على: 
البنيانات المختلفة للتطبيقات المحمولة 
محاسن ومساوئ کل منها 
استعراض مجموعة من التطبيقات التي تعتمد كل من هذه البنيانات 
تقنية التراسل و استخدامها. 
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بنيان التطبيقات المحمولة 
تتدخل الكثير من العوامل في تحديد طبيعة الحلول المحمولة ونجاعتها. من أهم تلك العوامل بنيان تلك التطبيقات. 


سنتحدث في هذه الجلسة عن ثلاث نماذج لبنيان التطبيقات المحمولة وهي: 
- الانترنت اللاسلكية 
الزبون الذكي 
- التراسل. 


العوامل التي تؤثر في اختيار بنيان التطبيقات 


مستخدمو التطبيق: 
يؤثر نوع المستخدمين بشكل كبير على البنيان المستخدم في التطبيق حيث لا بد من تحديد من هم هؤلاء المستخدمون» ما هي مهارتهم 
التقنية وما هي سيناريوهات الاستخدام التي قد يتبعوها. 


نوع التجهيزات: 

يجب التفكير هنا بإمكانية دعم التجهيزات المتوفرة للتطبيق» وما هي التجهيزات الأنسب اللتعامل معهء وهل توفر التجهيزات إمكانية 
الاتصال اللاسلكي مباشرة أم أنها تحتاج للربط مع جهاز آخر ليؤمن لها الاتصال. 

تضاف إلى ماسبق عوامل تتعلق بقدرة الجهاز على تأدية أكثر من عمل في وقت واحد»ء كالاتصال بالانترنت مثلاً وإرسال رسائل 
8 في نفس الوقت. 


الاتصال بالمؤسسة: 


# ما هي الآلية التي ستتم بها عملية الاتصال مع المؤسسة؟ وهل هي لاسلكية أم سلكية (كحال اتصال يعتمد وصلة 088)؟ 


® في حالة الاتصال اللاسلكي» ماهونو ع الشبكة المُستخدمة ((4 W1۸۸, °۸, WW‏ أواتصال عبر الأقمار 
الصناعية)؟ 


# ماهو نوع الاتصال المُستخدم وما مدى تأثيره على كمية البيانات التي يجب إرسالها من التطبيق المحمول إلى مخدم 
المؤسسة؟ 


انات تة 
© ما هوحجم البيانات الواجب توفره لمستخدم التجهيز المحمول؟ 


# أين يجب أن تتوضع البيات» على الطرفية المحمولة للزبون أم على مخدم المؤسسة؟ 
# هل من المجدي تحميل البيانات في الزمن الحقيقي عبر الاتصال اللاسلكي أم أن هناك ضرورة لعملية تخزين للبيانات على 
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طرفية الزبون؟ 

ما هي الديمومة المطلوبة للبيانات؟ وهل ستحتاج إلى التحديث بشكل مستمر كما هي الحال في معلومات أسعار الأسهم 
والبورصة؟ أم تكفي عملية تحديث يومية كما هي الحال في المخازن؟ 

هل يمتلك كل مستخدم جهاز وحيد للوصول إلى التطبيق أم عدة أجهزة؟ 

هل يمكن للمستخدمين الاشتراك باستخدم نفس الجهاز دون المخاطرة بخلط بياناتهم؟ 


هل سيكون هناك تضارب لدى تحديث البيانات للمؤسسة من الطرفيات المختلفة؟ 


التكامل مع المؤسسة: 
٠‏ هل يوفر التطبيق إمكانية التكامل بين الزبون والمخدم في المؤسسة عبر واجهات برمجية خاصة؟ 


إخطار المستخدم: 
٠‏ هل يحتاج المستخدم إلى استقبال تتبيهات خاصة؟ 
٠‏ وفي حال كان المطلوب هو إرسال إشارة إلى المستخدم فهل يمكن استخدام أجهزة الهاتف الخليوي العادية وأجهزة التنبيه لهذا 
الغرض؟ 
٠‏ وما الذي سيحدث في حال كان الجهاز المحمول للمستخدم مغلقا؟ 


الأمان: 
٠‏ كيف يمكن حماية البيانات الحساسة أثناء إرسالها أوعلى الجهاز؟ وماهي سوية الأمان وآلية تطبيقها ومكان تطبيقها 
(مخدم»زبون)؟ 
٠‏ هل تعتبر الفيروسات أحد الأخطار الواجب الاحتياط لها؟ وماذا عن عملية سرقة الجهاز أوضياعه؟ 


عمر البطارية: 
٠‏ هل يعتبر استهلاك الطاقة أحد الأولويات؟ 
٠‏ ما مدى مدى استهلاك الاتصال اللاسلكي للطاقة؟ 
٠‏ هل تتوفر بطارية احتياطية؟ وهل يمكن أن يتم شحنها أثناء العمل؟ 


نادرأ ما تتطابق الحاجات التي يقدمها البنيان المتوفر مع جميع احتياجات التطبيقات. لذلك سيكون هناك ضرورة للمقايضة بين مختلف 
المزايا للوصول إلى التركيبة الأكثر مناسبة. 
يوضح الشكل التالي العلاقة بين تعقيد الحل» وبين زيادة الإمكانيات وضرورة تثبيت برنامج على طرفية الزبون. 
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ليس هناك حاحة 
لتثبیت برنامج من 


x: 
کے‎ 
e ١ 


ل 


ANE ANH A$ 


سنقوم فيما يلي بالاطلاع على معماريات مختلفة وذلك بغرض معرفة الفوائد التي يمكن أن نجنيها على مستوى التطبيق لهذ المعماريات 
هي : 

1- بنيان الانترنت اللاسلكية 

2- بنيان الزبون الذكي 

3- بنيان تطبيقات التراسل. 


بنيان الانترنت اللاسلكية 


a 


Wireless 
Microbrowser 
Clients 


Basê Station 
Enterprise 
Data Sources 


Mobile User Inside Corporate Firewall 


يتشابه هذا البنيان مع بنيان السلكية مع فارق يكمن في كون آلية الاتصال مع المستخدم النهائي لاسلكية. يتركز منطق العمل والبيانات 
في هذا البنيان عند المخدم» أما من طرف الزبون» فيجب أن يحتوي الجهاز المحمول على مستعرض أوما يسمى أحياناً مستعرض 
صغري دون الحاجة لتثيت برامج أخرى من طرف الزبون. لذلك تدعى أحياناً هذه التطبيقات بتطبيقات الزبون الرقيق. 

العناصر الأساسية لهذا البنيان: 
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المستعرض الصغري: يقوم المستعرض بإرسال طلب يحتوي عنوان المصدر القياسي 0R‏ إلى المخدم. تأتي الاستجابة من المخدم 
على شكل لغة تأشير حيث يقوم المستعرض بتفسيرها وإظهار المحتوى على شاشة الجهاز المحمول. 

في حال كانت التقنية المحمولة لا تستخدم بروتوكول 1۴ سيكون هناك حاجة إلى استخدام عبارۃة لتحویل الطلبات إلى طلبات 1۲۲۶۴ يتم 
توجيهها إلى مخدم الوب. 

مخدم الوب اللاسلكي: تتلخص مهمة مخدم الوب هذا في استلام طلبات 1۲۲۶ وإرسال الرد المناسب. لضمان استجابة مناسبة 

للمستعر ضات المختلفةء نظا لحاجة هذه المستعر نات إلى استخدام لغات تأشير مختلفةء يجري تتبيت إطار عمل خاص على المخدم 
يساعد في تشكيل استجابة المخدم حسب المستعرض الذي قام بإرسال الطلب. 

مصدر البيانات في المؤسسة: يقوم مخدم الوب اللاسلكي بالوصول إلى مصادر البيانات في المؤسسة حيث تعتمد آلية الوصول 
ومصادر البيانات المعتمدة على عوامل تتعلق بحساسية البيانات وحجم الوصول ووجود آليات وصول بديلة. 


محاسن ومساوئ بنيان الانترنت اللاسلكية 


تكون الحاجة إلى تثبيت برمجيات على طرف الزبون معدومة أوبالحد الأدنى. 

توسيع الإطار الذي يستخدم الانترنت حيت تومن هذا البنيان امتداد طبيعي للتطبيقات التي تعمل على الانترنت السلكية 
واجهة المستخدم المألوفة: حيث أن معظم المستخدمين معتادين على استخدام واجهة المستعرض في تطبيقاتهم. 
التكاملية مع المؤسسة: تصبح عملية التكاملية في معظم الأحيان مؤمنة تلقائياً في هذا البنيان كونها تعتمد الانترنت. 


تمكين التوزيع العريض: وذلك لكون عملية أقلمة المكونات لتناسب المستعرضات على الأجهزة المحمولة المختلفة مسؤولية 
المخدم. 

البيانات الحديثة: تومن هذا البنيان كون البيانات بنسختها الأخيرة كون المصدر لهذه البيانات هومخدم الوب ولن يكون هناك 
تخزين على طرف الزبون. 

الأمان: كون البيانات مخزنة على المخدم. 


المساوئ : 
- الاتصال اللاسكي: تتطلب عملية الوصول إلى البيانات الاتصال بالمخدم لاسلكياً مما يشكل أحياناً صعوبة وبالأخص أثناء التنقل 
بين الأماكن المختلفة. 
واجهة المستخدم البسيطة: غالبا ما توفرالمستعرضات الصغرية قدرات بيانية محدودة مما يجعل من غير المناسب استخدام 
اأضتور 
أداء التطبيق: يرتبط أداء التطبيق بشكل كبير بأداء وفعالية الشبكة. 
اختبار التطبيق: تكون عملية اختبار التطبيق مشكلة في مثل هذا البنيان مع التنوع الكبير في المستعرضات الصغرية. إذ لا 
تكون الاختبارات دقيقة بالقدر المطلوب حتى بوجود برمجيات المحاكاة للتجهيزات. 
الجاهزية: تسبب أي مشكلة قد تطراً على المخدم توقف عمل جميع المستخدمين. 
الأمان:لا يوجد سيطرة كاملة على البيئة وذلك بسبب وجود العبّارة اللاسلكية والتي قد تعتبر أحد نقاط الضعف. 
الكلفة: تصبح الكلفة في كثير من الأحيان عائقاً في مثل هذا البنيان بسبب اضطرار المستخدم إلى تأسيس اتصال لاستخدام 
التطبيقات. 
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هن هم الأمثلة على التطبيقات المناسبة لهذا البنيان هي: 
1- تجارة السندات والبورصة: حيث تبرز أهمية الحصول على أحدث البيانات حول الأسعار الآنية كون عملية التحديث تتم آنياً 
على مخدم الوب. 
خدمات المعلومات. 
خدمات التسلية : كالأبراج والألعاب والأحاجي. 
التجارة المحمولة. 
بنيان الزبون الذكي 


يشكل بنيان الزبون الذكي بديلاً قوياً لبنيان تطبيقات الائترنت اللاسلكي. 

تعتمد هذه التقنية على تطوير برنامج خاص يتم تثبيته في طرف الزبون يحتوي هذا البرنامج عادة على قاعدة البيانات إضافة إلى 
طق العمل : 

يعني وجود هذا البرنامج على طرف الزبون إمكانية عمل الزبون في أي مكان أوزمان دون الحاجة إلى الاتصال. 

تتم عملية التكامل مع المؤسسة بإجراء عملية مزامنة حيث يتصل التطبيق الزبون بقاعدة البيانات في المؤسسة عبر مخدم مزامنة. 
يمكن لعملية الاتصل بغرض المزامنة أن تتم عن طريق اتصال ص1/مء)ء اتصال تسلسلي أو .05S8‏ 


Synchronization 
Server Enterprise 
Data Sources 


Firewall 


Mobile User Inside Corporate Firewall 


يحثاج نثبيت برتامج على الجهاز المحمول إلى توفر نظام تشغيل لدعم التطبيق مع ضرورة وجود مكتبات خاصة تابعة لنظام التشغيل 
هذا ليقوم التطبيق باستخدامهاء كما يمكن أن يكون استخدام تطبيقات مطورة بلغة جافا بديلاً مناسياً أيضا. 
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مكونات بنيان الزبون الذكي 


الزبون الذكي: تطبيق الزبون الذي يحتوي على منطق العمل. 

مخدم المزامنة: يتم إرسال البيانات من التطبيق الزبون إلى مخدم المزامنة الذي تتلخص مهمته في مزامنة بيانات المؤسسة مع 
بيانات التطبيق الزبون حيث يقوم بتأمين هذه العملية بالحد الأدنى من البيانات المنقولة. 

مصدر البيانات الخاص بالمؤسسة: يقوم مخدم المزامنة بالوصول إلى مصدر البيانات في المؤسسة باستخدام تقنية الاتصال 
المفضلة. 

يمكن أن تستلزم عملية المزامنة الاتصال بمخدم المزامنة لحين انتهاء المؤسسة من معالجة البيانات. 


محاسن ومساوئ بنيان الزبون الذكي: 


محاسن بنيان الزبون الذكي: 

1- التوفر الدائم للبيانات: حتى في حال عدم وجود اتصال لاسلكي يستمر المستخدم بالعمل وبتعديل معلومات المؤسسة على أن 
نتم مزامنة هذه التغيرات لاحقا. 
غنى واجهة الاستخدام: حيث يمكن تطوير واجهات رسومية وبيانية للتطبيق الذكي في حال حواسب الجيب الشخصية مثلا. 
كما يمكن اعتماد مجموعة جزئية من الوظائف التي يقوم بها نظام التشغيل ۷1N(0WS‏ لتوفير مكونات بيانية غنية. 
الأداء: لن تتم إضاعة الأداء في محاولة اتصال مستمرة للوصول إلى البيانات بل يعتمد الأداء على سرعة المعالج وسرعة 
الوصول إلى البيانات على الجهاز المحمول. 
المعالجة الموزعة: إن عملية تنفيذ منطق العمل من طرف المخدم تخفف من عبء العمل عن المخدم مما يسمح للمؤسسة 
بشراء مخدمات أقل كلفة. 
الأمان: يمنح تطبيق آلية أمان بين النهايات ( المخدم والزبون) تحكم أكبر وسيطرة على طرفي تراسل البيانات ولا يكون 
هناك تخوف من نقاط الضعف التي فرضتها العبّارة في بنيان الانترنت اللاسلكية. 
الكلفة: يجري في هذا البنيان تخفيف كلف الاتصال اللاسلكي للحد الأدنى وذلك بسبب الحاجة للاتصال فقط عند إجراء عملية 
المزامنة ولمدة قصيرة بحيث يتم تقليل كمية البيانات المتبادلة أثناء المُزامنة للحد الأدنى. 

مساوئ بنيان الزبون الذكي: 

المكاملة مع المؤسسة: تتطلب عملية المكاملة بين تطبيقات الزبون الذكي وتطبيقات المؤسسة وقتاً أكثر والمزيد من الموارد نسبة 

إلى تلك اللازمة في حالة بنيان الانترنت اللاسلكي. 


تثبيت البرنامج من طرف الزبون: تعتبر عملية تثبيت وإدارة التطبيق على الجهاز الزبون عملية غير صعبةء ويمكن إجراؤها عن 
بعد ولكنها تصبح عبئاً في حال وجود عدد كبير من الزبائن. 


فيروسات الموبايل: يفتح استخدام نظام تشغيل خاص بالتجهيزات المحمولة المجال أمام خطر الفيروسات. بالرغم من وجود حلول 
لهذه المشكلة بحيث يمكن تطبيقها أثناء تثبيت التطبيق الزبون إلا أن وجود المشكلة بحد ذاته أضاف مزيداً من العبء. 
تعقيد عملية التطوير: تجري عملية تطوير التجهيزات المحمولة إنجازها باستخدام واجهات تطبيقات برمجية تابعة لنظام التشغيل 


Universal Knowledge Solutions s.a.1 
32 


الخاص بجهاز محمول بعينه» مما يجعل عملية تطوير برمجيات تابعة لمجموعة كبيرة من التجهيزات مشكلة حقيقية. وفرت اللغات 
المستقلة عن منصة العمل متل ۷4[ حلا لا بأس به لهذه المشكلة. 


تعدد دورات التطوير: في حال تعدد أنواع التجهيزات وأنظمة التشغيل تبرز أهمية إنشاء دورات تطوير واختبار مختلفة لكل نوع 
من هذه التجهيزات مما يستنزف الموارد. 


تطبيقات بنيان الزبون الذكي 


من أهم تطبيقات بنيان الزبون الذكي التطبيقات التالية: 


1- فرق المبيعات المؤتمتة: 

تد ية الخصرل ى السارنات الخال ة من أ عاضر تجاح حل ايع ل فمل إنكائية وصول مقرب بيعت إلى 
المعلومات أثناء مقابلته للزبون» نقطة الفصل أحياناً في إتمام هذه العملية. 

كن تات فرق ميات الموقكة أرما سى (5۴4)ء مقرت امات من الوضرل إلى مطرمات مخطفة كار مات كا 
بالزبون؛ ومطومات ميات الشراء آي قام بها مسقا ومطرمات متعطقة بكتالىجات المنتجات ولراتح الأسالء رلراج 
الموجودات في المستودع» وكذلك بعمليات البيع الحاصلةء حيث يمكن للمندوب مزامنة المعلومات كلما استدعت الحاجة. 


2- تطبيقات فرق العمل الحقلية وعمليات جمع البيانات: 
تساعد تطبيقات فرق العمل الحقلية على تمكين جمع البيانات ومزامنتها مع بيانات المؤسسة دون الحاجة إلى الدخول في الأعمال 
الورقية التي تستهلك الوقت. 


3- تطبيقات العناية الصحية: 
توفر مثل هذه التطبيقات معلومات تفصيلية عن المرضى للأطباء واتسهل أعمال كتابة الوصفات ومعالجتها مع شركات التأمين 
الصحي. 


4- تطبيقات الانتاجية المحمولة : 


تساعد هذه التطبيقات الأشخاص العاملين في مجال الخدمات على تسجيل ساعات العمل التي قضوها في كل مهمة من المهام 
ومكاملة هذه السجلات لذى الموسسة: 


بنيان التراسل 


کن أطت الي كد خان رال ن ك الست ن الالء آي رج من كفل اريت الاتكر ر ي ر اله لى رة 
التراسل تطبيق إلى تطبيق. 


تستخدم عملية التراسل عادة إما كميزة إضافية للتطبيقات المتوفرة أو كبنيان مستقل للتطبيق. 
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تتوفر العديد من تقنيات التراسل وفيما يلي نقدم لأهمها: 

1- التراسل من نمط مستخدم لمستخدم: يتم في هذه التقنية إرسال الرسائل من مستخدم إلى آخر باستخدام العديد من الآليات أهمها 
البريد الالكتروني» أوالتنبيهء أوالرسائل النصية اللاسلكية مثل رسائل 51S‏ أوالتراسل المباشر 1۷ء في حين يمكن إرسال 
الرسائل التي تحتوي مكونات أغنى كالصور والنص المنسق باستخدام خدمة الرسائل المُحسّنة £18 أما بالنسبة للرسائل 
الحاوية على مكونات متعددة الوسائط فيمكن استخدام خدمة الرسائل متعددة الوسائط .×۷‰S‏ 
يمكن أن يتم توليد هذه الرسائل عن طريق إجرائيات من طرف المخدم كطريقة لتوزيع الرسائل. 


التنبيهات ورسائل الإخطار: 

يشمل هتا النوع الرسائل ذات الظبيعة العاجلة بطبيعتها والتي يمكن إرسالها إلى الستخدمين على أجهزتيم المحمولة. تمكن 
هذه التقنية الشركات من ضمان وصول المعلومات بشكل آني. 

من أهم التقنيات المستخدمة في هذا المجاJ‏ تبت .WAP Push,s HDML‏ 


لرل نط من لى نة 
في الكثير من الحالات لا يكون تفاعل المستخدم مطلوباً لنجاح التراسل إذ يكفي أن يجري الاتصال بين مخدم المؤسسة 
والتطبيق الزبون دون الحاجة إلى تدخل المستخدم. 
يقع هذا النوع من التراسل ضمن بنيان الزبون الذكي لأنه يحتاج أيضاً إلى تشيت تطبيق من جهة الزبون. 
يمكن للمستخدم أن يقوم بإرسال رسالة باستخدام التطبيق المثبت على الجهاز دون الحاجة إلى الاتصال في ذلك الوقت. يمثلك 
التطبيق الزبون رتل انتظار تتم فيه مراكمة المعلومات. 
ايلي شكل توضيحي بين تفية التزاسل من تطبيق إلى تطبيق: 


Client 
Application 


Message Queue 


Client 


Messaging 
Server Database 


Firewall 


Mobile User Inside Corporate Firewall 
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بنيان التراسل 


مگونات بذيان اثر اسل من تطبيق إلى تطبيق: 


زبون التراسل: 
يعبر عن التطبيق الحاوي على رتل الرسائلء إضافة إلى منطق العمل من جهة الزبون. 


مخدم التراسل: 

يمتل مكون المخدم جزء النظام الذي يقوم بالاتصال بزبون التراسل من جهةء وبمصدر البيانات في المؤسسة من طرف آخر. 
يطلق على مخدم التراسل أحيانا اسم الإطار الوسيط الخاص بالرسائل .0١۷‏ 

يتم تطوير معظم هذه الأنظمة باستخدام خدمة جافا للرسائل 18ل حيث تزود تلك الأخيرة منصة عمل ذات اعتمادية ومرونة 
عالية لتطوير مثل هذه الأنظمة. 


يمكن لمخدم التراسل الاتصال والتفاعل مع مجموعة كبيرة من مصادر البيانات كقواعد البيانات وتطبيقات الأعمال وأنظمة الثر اسل 


الأخرى. 


محاسن ومساوئ بنيان التراسل 
المحاسن: 
نيات الدفع: يمكن تحسين عمل تطبيقات الأنترنت اللا الزبون الذكي من خلال آلية دفع الرسائل. فمثلاً بالنسبة للانترنت 
إمكانيات الدفع: يمكن تحسين عمل تطبيقات الأنترنت اللاسلكي والزبون الذكي من خلال آلية دفع الرسائل. فمثلاً بالنسبة 
اللاسلكي» يمكن إخطار المستخدم بضرورة إجراء عملية المزامنة في حال بنيان الزيون الڏنکي. 


التخزين والتوجيه: يتم في هذا البنيان تخزين الرسائل ووضعها في رتل انتظار أي يمكن أن يعمل المستخدم على إرسال الرسالة 
حتى في حالة عدم الاتصال حيث تتم إعادة توجيه الرسائل عند تأسيس الاتصال. 


الاتصال السلكي واللاسكي: يمكن لهذه التقنية أن تعمل باستخدام الاتصال السلكي أواللاسلكي في حين يتطلب التراسل من نمط 
مستخدم إلى مستخدم الاتصال اللاسلكي. 


المساو ئ: 
تقنية التراسل هي تقنية كيفية غير إجبارية وعادة لا تتم إضافتها ما لم تتبت فائدة واضحة لذلك لا تتضمن الحلول التي تعتمد هذه 
التقنية مساوئ واضحة فيما خلا زيادة التطبيقات تعقيداً. 


على أي حال تعتبر هذه التقنية شعبية بين المستخدمين ويتم اعتمادها في التطبيقات المختلفة سواء تلك المخصصة للاتصال بين 
الأشخاص أو لأغراض التسلية كإرسال نتائج المباريات وتنبؤات الأبراج كذلك في الأغراض المرتبطة بالأحداث الاقتصادية وأسعار 
البورصة والأسهم. 
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القسم الخامس و السادس: 


لغات التأشير وتقنيات توليد المحتوى 
الكلمات المفتاحية: 


تطوير› المحتوى» لغة تأشير»ء تأشيرة» واصفة»ء تعبير . 


ملخض : 
سنحاول في هذه الجلسة تغطية موضوعين أساسيين الأول يتناول لغات التأشير المستخدمة في تطوير التطبيقات اللاسلكية والثاني يتناول 
تقنيات توليد المحتوى. 


أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على: 
٠‏ لغات التأشير المُستخدمة في تطوير التطبيقات اللاسلكية 
٠‏ تقنيات توليد المحتوى. 
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اللغات اللاسلكية وتقنيات توليد المحتوى 


نغطي في هذه الجلسة موضوعين أساسيين: يتناول الأول لغات التأشير المستخدمة في تطوير التطبيقات اللاسلكيةء ويتناول الثاني تقنيات 
توليد المحتوى. 


أنماط المحتوى اللاسلكي 

يدخل في إنشاء تطبيق لاسلكي مجموعة من الأنواع المختلفة للمحتوى بما فيها لغات التأشير» والصور» والوسائط المتعددةء والملفات 
المختلفة المتعلقة بعمل التطبيق. 

غالباًء لا نحتاج -في معظم التطبيقات الخاصة بالهواتف المحمولة أوالتجهيزات التي تدعم ۷4۴- إلا إلى التركيز على لغة التأشير 
وبعض الصور البسيطة» أما إذا كان السوق المستهدف بالتطبيق يتضمن التجهيز ات القادرة على تشغيJ‏ iظnة‏ ک— Windows CE‏ 
أر 08S‏ مهiطصر؟‏ فلا بد عندها من التركيز على عناصر إضافية كعناصر الوسائط المتعددةء وملفات التطبيقات المختلفة 
ک—MSWord.‏ 


لغات التأشير: 
عندما نقوم بتطوير تطبيقات إنترنت مكتبية نلجأً غالبا إلى لغة تأشير. 
من بين لغات التأشير الأكثر شيوعاً في هذا المجال لغة ا11 فهي قادرة على تمثيل المحتوى لأغلب المستعرضات مثل 18ء 
Netscape «Mozilla‏ ... 
للأسف هذه ليست الحال بالنسبة للعالم اللاسلكي حيث يمكن يتم استخدام لغات CHTML «HTML «WML «HDML Jin‏ 
و X11‏ على مستعرضات مختلفة» والعوامل الذي تحدد اختيار أي من تلك اللغات تتعلق بالموقع الجغرافيء ونوع الجهازء 
والمستعرض الصغري المستخدم. 
غ HDML‏ 


یترکز استعمال لغة 101 بصورة أساسية في منطقة أمريكا الشمالية نظراً لكون أغلب التجهيزات المحمولة المطورة للاستخدام في 
أمريكا الشمالية تدعم هذه اللغة. وقد كانت الفكرة خلف تطوير هذه اللغةء إنشاء لغة تأشير خاصة بالهواتف المحمولة. 


تتشابه [D1‏ مع 11M‏ من حيث البنية لكنها لا تقترب من الإمكانيات الواسعة التي تمنحها 111 . 


تكمن أحد أهم نقاط ضعف 15۷11 في أنها لا توفر لغة خطاطية كالتي توفرھا ا11 مثل ام Javascr1‏ أوVBseript.‏ أوكالتي 
توفر ھا WM‏ مثل »WMLSorip†‏ مما يجعل ا12۷ غير قادرة إلا على تنفيذ المنطق المتوفر على الجهاز المحمول المُستخدم 
لیس إلا. 

لذلك فإن عمليات متل التحقق من الإدخال» وتوليد الرسائلء وتوليد مربعات الحوارء لا يمكن تطبيقها إلا كنصوص برمجية من جهة 
المخدم ولا يمكن تنفيذها من جهة الزبون مما يسبب بالطبع ازدياد كميات البيانات الواجب نقلها على الشبكة اللاسلكية وبالتالي إلى 


خفض الأداء. 


لكن» بالرغم من المآخذ على هذه اللغةء ليس بالإمكان التغاضي عن استخدامها وبالأخص عندما نعلم أن ملايين التجهيزات في أمريكا 
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وكندا تستخدم المستعرضات العاملة على .HDML‏ 


يتلخص أحد الحلول المطروحة في إضافة عبّارة تقوم بتحويل 12M‏ إلى ا١۷‏ بحيث يصبح بالإمكان التعامل مع التطبيقات 
الخاصة ب اM([‏ باستخدام التجهيزات التي تدعم اWM.‏ 


:HDML ةخغl‎ ùع مثال‎ 


Inventory Search 
1}غSsearch‎ by Hame 
Z2 Search by SEU 
3 Inventary List 


SEA DML VERS TONE SOS 
GE HOUCES 
<CENTER><b>Inventory Search</b> 
<CE TASK="GO" DEST="FProductSearch">Search BY Name 
<CE TASK="GO" DEST="#SKUSearch">Search by SKU 
<CE TASK="GOSUB" DEST=inventorylist. jsp>Inventory List 
cC ACOMOLCES 
<ENTRY NAME="ProductSearch" KEY="ProductName"> 
SACU TON IEE =  NECEEM MASK = EOL 
DEST=T"PrTOIUCESEACCN. ISP PEOQUCT=SPrOUUCENaAME" > 
Enter Product Name: 
< /ENTANS 
<ENTRY NAME="SKUSearch" KEY="SKU"> 
<ACTION TYPE ACCEPT TASK=TGUT UDEST=SKUSEATChN.,. JSD SKU= SKU. 
MEE SUS 
1S.  <AANIRES 
16.<( HDMLS 


نلاحظ أن <11× 12> تبدأً برقم النسخة. 
يقسم النص البرمجي في ۳1ط إلى ما يسمى منصات وبطاقات. 
يعبر المثال السابق عن محتوى منصة وهي القطعة من النص البرمجي التي يجري تحميلها. 
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تحتوي كل منصة بطاقة أومجموعة بطاقات» ففي حالة مثالنا لدينا ثلاث بطاقات هي تلك المحددة بالتأشير ات <عءزهط٤>‏ 
ڪو>Entry<‏ 


© يتم التعامل مع كل بطاقة على أنها صفحة منفصلة 


€ تسمح 121 بالانتقال بين البطاقات المختلفة 


€ نلاحظ في مثالنا أنه تم استخدام التأشيرة <011010#> للحصول على دخل من المستخدم» وهي الطريقة الأفضل للإدخال 
تقر السرا ع الخال ع اليرت او ك رة 
© تم استخدام الواصفة DE81‏ لتحديد البطاقة أوالمنصة الهدف. 


© تم استخدام التأشيرة <را)8> للحصول على دخل من المستخدم عن طريق لوحة المفاتيح. 


لمزيد من المعلومات حول هذه اللغة يمكن العودة إلى الوصلة التالية 
.http://demo.openwave.com/pdf/styleguides/hdml style.pdf‏ 


یترکز استعمال لغة 101 بصورة أساسية في منطقة أمريكا الشمالية نظراً لكون أغلب التجهيزات المحمولة المطورة للاستخدام في 
أمريكا الشمالية تدعم هذه اللغة. وقد كانت الفكرة خلف تطوير هذه اللغةء إنشاء لغة تأشير خاصة بالهواتف المحمولة. 


تتشابه [D1‏ مع 11M‏ من حيث البنية لكنها لا تقترب من الإمكانيات الواسعة التي تمنحها 111 . 


تكمن أحد أهم نقاط ضعف 12۷1 في أنها لا توفر لغة خطاطية كالتي توفرها 111 مثل ام Javascr1‏ أوVBseript.‏ أوكالتي 
توفرھا WM‏ متل اNWMLScrip.‏ مما يجعل اH[2(M‏ غير قادرة إلا على تنفيذ المنطق المتوفر على الجهاز المحمول ال 
لیس إلا. 

لذلك فإن عمليات مثل التحقق من الإدخال» وتوليد الرسائلء وتوليد مربعات الحوارء لا يمكن تطبيقها إلا كنصوص برمجية من جهة 
المخدم ولا يمكن تتفيذها من جهة الزبون مما يسبب بالطبع ازدياد كميات البيانات الواجب نقلها على الشبكة اللاسلكية وبالتالي إلى 


خفض الأداء. 

لكن» بالرغم من المآخذ على هذه اللغةء ليس بالإمكان التغاضي عن استخدامها وبالأخص عندما نعلم أن ملايين التجهيزات في أمريكا 
وكندا تستخدم المستعرضات العاملة على .H1DML‏ 

يتلخص أحد الحلول المطروحة في إضافة عبّارة تقوم بتحويل ا12۷ إلى ا۷۷ بحيث يصبح بالإمكان التعامل مع التطبيقات 
الخاصة ب اM([‏ باستخدام التجهيزات التي تدعم اWM.‏ 


WML أغة‎ 


سبق وذكرنا أن لغة ۷M‏ هي جزء من بيئة التطبيقات اللاسلكية ۷۸۴ حسب ما تم تعريفه في البروتوكول .W۸۴‏ 
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تم تأسيس WM‏ -بعكس M1‏ 12- على لغة ۷1× لذا فإن قواعد الصياغة فيها أكثر صرامة. 


تقو اWM‏ خليفة ا( وقد تم تطويرها بصورة أساسية لتكون موجهة إلى التجهيزات المحمولة كأجهزة ٠۶04‏ والهواتف 
الخليويةء والهواتف الذكية. 


تلقى ۷1 الدعم الكامل من معظم شركات التجهيزات المحمولة مما يجعلها الخيار الأفضل كلغة تأشير في تطوير التطبيقات 
المحمولة. ولکن مع ظهور 0 والتي تعتمد M11‏ 1× كلغة تأشير لا نعلم کما ستستمر هذه اللغة في الاستخدام. 


مثال عن لغة :W M1‏ 


مشتفرضن فما بلي مالا ذم أشن الرظفة التي ر تاها في المقان الخاضن دا5 ركن اتتام فة ا هذه المرة 
OPENWAVE‏ 2 


Inventory Saarch 
1}5earch by Hame 
ã Search bY SEU 
3 Yievw Inventory List 


1l, <?xml vEESION="1.,.0" encoding UTE OT 
20 GIDOLILES WML EUESLLE F-7 (WAEBFORUV DID ML 1.1/77 
NE EOS U o EOE OE UI o OE ADDN LÛ Ml HS 
<wml> 
<Cald I1d=Fcardlrz 
<8 ali omM- eeNEEL AS INVERN EOEY SEARO <C 71 AO 
<p align="left"; 
<select> 
<option>Search by Name 
<onevent type="onpick"> 
<go href="#ProductSearch"></go> 
</onevent> 
AOE LOM 
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<option>Search by SKU 
<onevent type="onpick"> 
<go href="#SKUSearch"></go> 
</onevent> 
OPES ORS 
<option>View Inventory List 
<onevent type="onpick"> 
<go href="Inventorylist.wml"></go> 
</onevent> 
< OIE LORS 
</select> 
E 
€ CENE OS 
<cCard 102" Product Search 
ML EOE Mere FOE EEOAUSCE SESE 
IS 
Enter Product Name: 
<input name= "product" emptyok="false"></INGUL> 
<02 
G/ CEEAS 
<card id="SKUSearch"> 
<! -—-WML code here for SKU Search--> 
<P> 
EEE UE 
<input name="sku" emptyok="false"></input> 
</0 
G/ CAE 
</wml> 


تحافظ ا۷ على صيغة المنصات» والبطاقات المستخدمة في 12M‏ ومثالنا كما نلاحظ يحتوي أيضاً منصة واحدة وثلاث 
بطاقات. 


يمكننا ملاحظة الصيغة التي تشبه صيغة ملف :×٧1‏ 
€ تم التصريح كما نرى أولاً عن نوع الوثيقة 
€ تم التصريح عن البطاقة بالتأشيرة <ل۲هء> وتم استخدام التأشيرة <اءء1ءء> للحصول على خيار المستخدم 
© تم استخدام التأشيرة <انام > للحصول على دخل المستخدم بشكل مشابه لاستخدام التأشير ة < <E try‏ في HDML Ja‏ 
© هناك تشابه كبر بين التأشيرات في M1‏ وتأشيرات HTML‏ 


€ تقدم ۷11 عدة طرق للانتقال بين البطاقات والمنصات منها الطريقة التي يقدمها المثال باستخدام التأشيرة <0ع> مع 


<onevent> 5 التأشیر‎ 


أبرز ما يجب التركيز عليه في ا١۷‏ هوالصرامة الشديدة في التعامل مع التأشيرات إذ لا بد من إغلاق كل التأشيرات»ء ويجب تلافي 
وجود أي تقاطعات بين التأشيرات (يجب أن تكون مُعلبة تماما ببعضها البعض) كما يجب أن تستخدم التأشيرات الحروف الصغيرة. 
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WMLScript 


.HTML ف„‎ javascript Joli „ag WMLScrIpt تتضمن ۷1 لغة خطاطية تسم‎ 


تمكن م MS‏ من إضافة منطق عمل من طرف الزبون» مما يقدم الكثير من الميزات كتقليل زمن الانتظار» وتخفيف العبء 
على الشبكة اللاسلكية. 


من هم mlتخدlمlٽ :WMLScript‏ 
€ عمليات التحقق من الإدخال 
€ إمكانية الوصول إلى التسهيلات التي يقدمها الجهاز: كإمكائية إضافة اسم» أورقم إلى دليل الأرقام على الجهاز 


€ رفع سوية التفاعل مع المستخدم بتوليد الرسائل ومربعات الحوار من طرف الزبون دون الحاجة إلى المخدم في هذا العمل 


لكي نتمكن من استخدام لغة M86٣٤‏ في التطبيقات» يجب أن توضع النصوص البرمجية التي نود استخدامها في ملفات تملك 


wصاء.ةقحاللا‎ 


مثال: 
فيما يلي مٿاJ‏ بيط عj‏ wlتخدlم WMLScript‏ 


<a href="validateuser.wmls#fEoo ($ (USErE) )>Validate User </a> 


نری هنا اننا استخدمنا التابع ٤٥٥‏ من الملف ءا use۲.wعidatاva.‏ 


للمزيد من المعلومات حول هذه اللغة يمكن العودة إلى الوصلة التالية 
http://demo.openwave.com/pdf/50/wmls_ dev guide.pdf‏ 


.HTML ف„‎ javascript Joli „ag WMLScrIpt لغة خطاطية تسم‎ ۷M تتضمن‎ 


تمكن امذإ M8٥‏ من إضافة منطق عمل من طرف الزبون» مما يقدم الكثير من الميزات كتقليل زمن الانتظارء وتخفيف العبء 
على الشبكة اللاسلكية. 


من هم mlتخدlمlٽ :WMLScript‏ 
© عمليات التحقق من الإدخال 
€ إمكانية الوصول إلى التسهيلات التي يقدمها الجهاز: كإمكائية إضافة اسم» أورقم إلى دليل الأرقام على الجهاز 


€ رفع سوية التفاعل مع المستخدم بتوليد الرسائل ومربعات الحوار من طرف الزبون دون الحاجة إلى المخدم في هذا العمل 
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لكي نتمكن من استخدام لغة ٤مإ6 WMS‏ في التطبيقات» يجب أن توضع النصوص البرمجية التي نود استخدامها في ملفات تملك 


اللاحفة كاصإس 


HTML أغ‎ 


يمتلك معظم المطورون خبرة ممتازة في استخدام لغة ٨11‏ لذلك لن ندخل في تفاصيلهاء ولكن يكفي القول هنا أًن -۷1 11 تعتبر 
من لغات التأشير الأساسية التي تقدم مرونة كبيرة تمنح المطور إمكانيات متعددة لتطوير التطبيقات التي نحن بصددها. 


تتعامل ا1۲۷ كما نعلم مع لغات خطاطية هي م۲1٥S‏ ۷8 وام ۷45۲هل وهي لغات تمكن الزبون من القيام بجزء من العمل دون 
الحا لى ا عة الرس من الكت 


مثال: 
فیما يلي مثال مشابه لما قمنا به باستخدام اللغات 812M‏ واWM‏ ولكن باستخدام لغة التأشير :H 1M‏ 


€ Û DOC AEE, BML USL LC WU AMNSCA DED SIML 3.2 Ei L/ ENES 
loi N 


<headz 
<title>Inventory List</title> 
</head> 
THO 
. <P align=left><FONT size=4><STRONG>Inventory Product 


LI1SE</STRONG></FONT> 
o GOC 
CDE 
<TABLE cellPadding=3 border=1> 

GIRS 
I D> GSN RON GS EEOGUGE C7 SN ROE TDS 
<TD <I ONG OUANLICL S/S ITONG ID. 
<TD><STRONG>Price ($) </STRONG></TD> 

Gf TRS 

GIRS 
IDS SOMY TEVIO 
GTDS L1 
DS 

Gf TRS 

GIRS 
STDS HI EACRS UMDS OL 
<TD>24 
DOS 

G/ TRS 

GIRS 
MDS SON DCE= HE HET 
MDS LL 
<ID>2199.99 

€/TRS 

GIRS 
<ID-IVC GE DV-000 
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IID > 4 
EDS LSI OF 
AUR 
< /RABLES 
</BODY> 
€ BUME 


تظهر نتيجة هذا النص البرمجي على مستعرض Microsoft Mobile 1nterne{ E×م1]0۲ء r‏ كما في الشکل التالي: 
Internet Explorer A 12:05 ×‏ 2 


Inventory Product List 


Product ouonty Price®) 
4 
1 


Hitachi 
Sony DLR-IP FBT 219,99 
JVC GRE-OWAOOD jj4 | 1533.99 


view Tools %4 © f CO | - 


يمتلك معظم المطورون خبرة ممتازة في استخدام لغة ٨11‏ لذلك لن ندخل في تفاصيلهاء ولكن يكفي القول هنا أًن -۷1 11 تعتبر 
من لغات التأشير الأساسية التي تقدم مرونة كبيرة تمنح المطور إمكانيات متعددة لتطوير التطبيقات التي نحن بصددها. 


تتعامل ا۳۲ كما نعلم مع لغات خطاطية هي م۲1٥؟‏ ۷8 وام1إء5 ۷2هل وهي لغات تمكن الزبون من القيام بجزء من العمل دون 
الحاجة إلى إعادة تحديث المحتوى من المخدم. 


غ CHTML‏ 
تعد 41M‏ من أكثر لغات ا11۷1 الجزئية شعبيةء وتسمى 11۷11 المدمجة ويعود سبب نجاحها لاستخدامها في خدمة 1-10٤‏ 
المُقدّمة من أكبر شركات الاتصالات في اليابان N1١ (0٤00١0‏ حيث تساعد هذه الخدمة المستخدمين في الوصول إلى محتوى 


الانترنت من خلال أجهزتهم المحمولة. 


لم يجر إضافة أي جديد إلى هذه اللغة وفي الحقيقة كانت عبارة عن لغة انتقالية تمهيدأً للانتقاJ .XHTML gl WMLy HDML jı‏ 
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عند إنشاء هذه اللغة تم أخذ العوامل التالية بعين الاعتبار: 


© محدودية التجهيزات بما فيها محدودية الذاكرة» والتوجه إلى خفض استهلاك الطاقة في عمليات المعالجة من قبل اللا ۴ء 
إضافة إلى مساحة الإظهار المحدودة 


© محدودية عملية الحركة بين الخيارات» والمعلومات» ومحاولة إجراء العمليات بأقل عدد من الخطوات 


© الاستقلالية عن الشبكة اللاسلكية المستخدمة 


تم تصميم -اCHM‏ بشکل کامل اعتماداً على توصيات ۷3٥‏ وكان التركيز بشكل أساسي على جعلها خفيفة تستطيع التعامل حتى مع 
إمكانيات الإظهار المحدودة» وعلى جعلها سهلة التطبيق. 


أهم العناصر التي دعمتها هذه اللغة: 
€ ڎصıر JPEG‏ 
© الأنواع والأنماط المختلفة للخطوط 
© الخلفيات (كألوان أوصور) 


€ صفحات الأنماط ٤88‏ 
بالرغم من اعتماد CH M1‏ على ٧١۲M‏ إلا أنها فقدت الكثير من أهميتها نتيجة لعدم إنشاؤها على أساس اM×.‏ 


لمزيد من المعلومات حول هذه اللغة يمكن العودة إلى الرابط التالي 
.WWW.W3.org/TR/1998/NOTE-compactHTML-19980209‏ 


XHTML ةغl‎ 


تعتبر لغة X111‏ نسخة من 11۷1 وتعتمد ۷1[ لذلك تتجه معظم التقنيات التي تعتمد لغات تأشير -ومنها الانترنت 
اللاسلكي للتجهيزات المحمولة- إلى محاولة دعم هذه اللغة لما تقدمه من إمكانيات موسعة. 


من أهم المجالات التي تمنح فيها هذه اللغة ميزات جيدة» مجال تطوير تطبيقات الأعمال الالكترونية المحمولة والأعمال المحمولة. 


تحولت نسخة ×11M11.0‏ إلى أحد المعايير الرسمية ل ۷3٥‏ في عام 2000ء وهي مطابقة ل H11۸11-4.01‏ ولكن مع 
إضافة بعض القواعد لضمان توافقها مع بنية ا١×.‏ 


لnاذ|‏ XHML؟‏ 
جاءت XH M1‏ بشكکل أساسي لتقيّد بصورة أكبر لغة -اMآ1ظ‏ بحيث تتمكن حتى المستعرضات التي لا تملك إمكانيات اكتشاف 
وتجاوز الأخطاء من العمل معها دون مشكلة. 
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كيف تلف ùe XHTML‏ HTML؟‏ 
تختلف XH#1 M1‏ عن 1۲M‏ في النقاط الأساسية التالية: 
- يحب أن يجر تنسیق صفحات X1۲۷11‏ بشكل جيد وفقاً لقو اعد XML‏ 
يجب أن يجر تعليب التأشيرات ببعضها البعض بشكل صحيح دون تقاطع 
يجب أن تستخدم التأشيرات والواصفات الحروف الصغيرة 
يجب إغلاق جميع التأشيرات في 11× حتى تلك التي لا تستخدم تأشيرة إغلاق في ا11۷ <8> التي تكتب في 
<br/> XHTML‏ 
يجب أن يجر حصر جميع قيم التأشيرات ضمن إشارتي < > 
يجب التصريح عن نوع الوثيقة. 


مثال: 
نعيد فيما يلي نفس المثال الوارد في الشرائح السابقة ولكن بلغة 11× 


o GML WEOCS LOM “OHS 
2 DOCITSEES MEml EUELINGE LE OE EIWAWME/ DID SHIT Mobile LOME 
"http ://www.openwave.com/dtd/xhtml-mobile10.dtd"> 
<REML xml NS REEO UN MO OO NOSSO SEM Son: aR SLE > 
<head> 
SEMELE > INMEREOSEY MSE EN Ee 
</head> 
<body> 
<p align="left"><font size="4"><strong>Inventory Product 
LISL</STEONO TONE ><> 
ET 
1O, <OE/S 
11. <table cell1Padding="3" border="1"> 
2 EE 
1I. CEN PIOUCT ETN 
2. e E 
SE SER EEICE(S) CER 
16» GEES 
Li. GEES 
1e SEE SIOR LEVSOS EEE 
19; CEO IT EE 
20. EE OOO OEE 
21 ET 
2 EES 
9 CECA LACM WUD 5L EOS 
24. cE Ad TES 
25. GEASS, IIS EAS 
20 VEE 
20o EES 
20 <ld>Sony DCR-TIPTBT</TA> 
29 TOIL TEE 
0 CAS 2199 I< EAS 
S1. JEEZ 
2 SEES 
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<td>JVC GR-DV2000</td> 
EO A4 TV E 
<TQA-1599 00E 
EE 
</table> 
<f OCS 
€ AEM 


تعتبر لغة X111‏ نسخة من ا1۲۷ وتعتمد ۷1× لذلك تتجه معظم التقنيات التي تعتمد لغات تأشير -ومنها الانترنت 
اللاسلكي للتجهيزات المحمولة- إلى محاولة دعم هذه اللغة لما تقدمه من إمكائيات موسعة. 


من أهم المجالات التي تمنح فيها هذه اللغة ميزات جيدةء مجال تطوير تطبيقات الأعمال الالكترونية المحمولة والأعمال المحمولة. 


تحولت نسخة ١M11.0‏ 11× إلى أحد المعايير الرسمية ل ۷3٥‏ في عام 2000ء وهي مطابقة ل 11114.01 ولكن مع 
إضافة بعض القواعد لضمان توافقها مع بنية -ا١×.‏ 


أaاذ|‏ XHML؟‏ 
جاءت XH M1‏ بشكکل أساسي لتقيّد بصورة أكبر لغة HM‏ بحيث تتمكن حتى المستعرضات التي لا تملك إمكانيات اكتشاف 
وتجاوز الأخطاء من العمل معها دون مشكلة. 


HTML ùe XHTML كيف تختلف‎ 

تختلف X311‏ عن 1۲M‏ في النقاط الأساسية التالية: 

- يحب أن يجر تتسيق صفحات X111‏ بشكل جید وفقاً لقو اعد XML‏ 

- يجب أن يجر تعليب التأشيرات ببعضها البعض بشكل صحيح دون تقاطع 
يجب أن تستخدم التأشيرات والواصفات الحروف الصغيرة 
يجب إغلاق جميع التأشيرات في 11× حتى تلك التي لا تستخدم تأشيرة إغلاق في ا11۷ ك <8۸> التي تكتب في 
<br/> XHTML‏ 


يجب أن يجر حصر جميع قيم التأشيرات ضمن إشارتي < > 
يجب التصريح عن نوع الوثيقة. 


XHTML-MP غ‎ 


تعتمد بيئة التطبيقات اللاسلكية وفق ما هومحدد في معيار ۷۸2 ما يسمى بالتشكيل المحمول ل X1۲1‏ أوما يطلق عليه 
.XHTML-MP‏ 


يعتبر هذا التشكيل مجمو عة جزئية من لغة 1۷× حسب ما هووارد في التعريف الذي حدده ۷3٣‏ . 


VoiceXML غd‎ 


وهي إحدى لغات التأشير الهامة التي تستحق الذكر في هذا الجزء من موضوعنا. 
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هي عبارة عن لغة تأشير مبنية على ۷1× تسمح بالوصول إلى محتوى تطبيقات الوب عن طريق الهاتف عوضا عن مستعرض 
الوب. يُستخدم لهذا الغرض مستعرض صوتي يقوم بتفسير لغة ۷٥1٥×M1‏ (تماما كما يفعل مستعرض الوب بلغات مثل 
«(WML j XHTML‏ ثم يقوم باستخدام محرك ۲5S‏ الذي يقوم بتحويل النص إلى صوت ويوجه المعلومات إلى المستخدم. 


تتلقى هذه اللغة الدعم من عدد كبير من الشركات العاملة في مجال الاتصالات والتقانة مثل 1 & ۸1ء M00۲1‏ و18۷1 والعديد 


غیرها. 


لن نخوض في التفصيلات حول هذه اللغة ولكن سنكتفي بإظهار شكل يوضح البنيان الخاص بتطبيق مثل هذه اللغة. 


1a: Request 
3a: Response ٦ 


(HTML page, jpeg, wav, ...) 
اتات‎ 


Web Browser 


Internet 


PSTN, > اےے‎ 


Landline Web Server | 


Voice Gateway 2: Application 
generates response 
ASR | Voice (JSP, ASP, COI, ...) 


ASR Browser 
1b: Request 
TERES 


٣ 1 
3b: Response 


(VoiceXML page, wav, ...) 


Cellular 


: VoiceXML jùع‎ Jû 
:VoiceXML ةغl سنقوم بایراد مثال بسيط لنص برمجي‎ 


xml verSI OM I OL 
SMU Me Si OM 2 OL 
<meta name=" author" content=" Martyn Mallick"/> 
E SES 
OILOC KS 
Welcome to the voice time entry system. 
OOIEO Mex OEM EOMS L/S 
€/ OLOEKS 
<EM> 
<!=- allow User to choose one of three options ==> 
<menu id=" options" dtmf=" true"> 
2o <BEOMGE > What Would vou Iike to do: Say one Cf: 
<enumerate/></prompt> 
13 <choice next="#entry">add entry</choice> 
14. <choice next=" 
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http://www.timeentry.example.com/vxml/delete.vxml"> 

delete entry</choice> 

15. <choice next=" http://www.timeentry.example.com/vxml/list.vxml"> 
NSE CRETE S MEMO EE 

1O <HOINGUL COUNT =I <TEDTOMNPE < ROINBUL > 

1. <noinput count="2"> Please state what action you would like 
<enumerate/></noinput> 

18. </menu> 

19, <! == cCGollect Cala TOE new time eNlly =. 

20U. TOE IO ETS 


2 <catch event=" nomatch noinput" count="3"> 

22 <prompt> Sorry, too many attempts. Please try again later. 
Goodbye. </prompt> 

2 <throw event=" telephone.disconnect.hangup"/> 

24. € CAEERAS 

29. <field name=" jobtype"> 

26 <DEOMpL-Wial IS Lhe 0G EYP EOE VOUT ENCE? <DIOMpEZ 

2 <option>design</option> 

28 <option>development</option> 

29. <option>meeting</option> 

0. TOE ICM EE EE L< {OIE LOS 

1. OIE LOM ZWACAE LOS OIE LOME 

2 <help>You must enter a valid job code to continue. Your options 
are design, development, meeting, travel, and vacation. 

<reprompt /></help> 

</Field> 

34. <field name=" hours" type="digits"> 

35 <pBFOMpL> How many hours For 0b <value Expr ="TObDIYDE />? 
SV BEOMOES 

IOs <help> use the keypad to enter the number of hours worked 
</help> 

0 </field> 

Io <field name=" proceed" type=" boolean"> 

e <prompt>Do you want to proceed with the entry for <value 
Expr = "NOUS" 7> hours EOL 0D LCvVbDe <value expr ="TObtYDeE 7>: </PDrEOMbDLZ 
40. <filled> 

4 <if cond=" proceed"> 

2 <PprOmMpt bargein=" false"> 

43. Your entry is being entered into the time system. 
44. </prompt> 

49 <!-- submit time entry to servlet for entry into database - 


<Ssubmit next="/servlet/entry" namelist=" jobcode hours"/> 
cfi 
<clear namelist=" jobcode hours proceed"/> 
<goto next="#options"/> 
</filled> 
</field> 
E OEM 
</vxml> 
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نلاحظ هنا أننا بدأنا بتحديد نمط الوثيقة )M1(‏ ثم استخدمنا تأشيرة فتح للوثيقة <المط×۷>. لكن ما نود التركيز عليه هناء هو أن 
عملية الإدخال تتم بأحد طريقتين إما بذكر الخيار بصورة صوتيةء أوباختيار رقم من لوحة المفاتيح الهاتفية. 


. 


XHTML-MP ۈ4غi‎ 


تعتمد بيئة التطبيقات اللاسلكية وفق ما هومحدد في معيار ۷۸۴2 ما يسمى بالتشكيل المحمول ل 11× أو ما يطلق عليه 
.XHTML-MP‏ 


يعتبر هذا التشكيل مجموعة جزئية من لغة ]× حسب ما هو وارد في التعريف الذي حدده ۷3٣‏ . 


VoiceXML ةغd‎ 

وهي إحدى لغات التأشير الهامة التي تستحق الذكر في هذا الجزء من موضوعنا. 

هي عبارة عن لغة تأشير مبنية على 1× تسمح بالوصول إلى محتوى تطبيقات الوب عن طريق الهاتف عوضاً عن مستعرض 
الوب. يُستخدم لهذا الغرض مستعرض صوتي يقوم بتفسير لغة 0×M11ء1ه۷‏ (تماماً كما يفعل مستعرض الوب بلغات مثل 
XHTML‏ أو اWM))»‏ ثم يقوم باستخدام محرك ۲۲9 الذي يقوم بتحويل النص إلى صوت ويوجه المعلومات إلى المستخدم. 


تثلقى هذه اللغة الدعم من عدد كبير من الشركات العاملة في مجال الاتصالات والتقانة متل 1&1 ۸ء 012إ0)هM‏ و 18M‏ والعديد 
غیرها. 
تقنيات توليد المحتوى 


بعد أن اطلعنا على أهم لغات التأشير اللاسلكية المستخدمة لا بد لنا من الاطلاع على بعض التقنيات الخاصة بتوليد المحتوى. 


تستخدّم هذه التقنيات لإنشاء التطبيقات اللاسلكية الديناميكية. وتمتلك كل من هذه التقنيات آليات تفاعل مع بيانات المؤسسة ومع منطق 
العمل المتوضع على المخدم» لذلك يكون باستطاعة المطور استخدامها لإنشاء تطبيقات لاسلكية مقادة بالبيانات. 


تكفا م اتقات نفا من الها اجات مخقة فة على طة لاز المسرل الى قل رسال الطاب ا سكن اطق راه 
مثلاً الاستجابة باستخدام لغات HDML‏ › أو WML‏ أو اM XH‏ حيث تشكل هذه الميزة نقطة شديدة الأهمية وبالأخص بالنسبة 


مع نتوع هذه التقنيات يصبح من الصعب اختیار أحدهاء ولكن غالباً ما يرتبط هذا القرار بالمهارات المتوفرة لدى المطور في إحدى هذه 
التقنيات»› وب بمجمو عة التقنيات الأخرى ١‏ لمستخدمة في المؤسسة خضوطا من ناأحية التطبيقات المكتبية والتي تفرض نفسها على 
التطبيقات اللاسلكية. 


سنستعرض في هذا الجزء من الجلسة مجموعة من هذه التقنيات وهي: 
Perl -CGI ~‏ 
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Java servlet 
Java server page 
Active server page 


XSL Stylesheets ga XML 


تقنيات توليد المحتوى 
PERL plدختlڊ‎ CGI -‏ - 


تعتبر تقنية C61‏ أحد أكثر أنواع تقنيات توليد المحتوى استخداماً وهي مدعومة تقريباً في جميع أنواع مخدمات الوب. 


تحتوي C61‏ مجموعة من الأوامر التي تسعد في تأمين الاتصال بين مخدم الوب والبرنامج الذي يقوم بمعالجة البيانات من صفحة 
الوب. وتعد هذه التقنية من أولى التقنيات التي توفرت لإنشاء المواقع الديناميكية. 


یجر تنفیذ ملفات ۴٥۲1‏ بالزمن الحقيقي بعكس المحتو ى الثابت الذي يكون عادة بصيغة نص. ويجري»› أثاء تنفيذ هذه الملفات» توليد 
المحتوى بشكل ديناميكي. 


يمكن كتابة برامج C61‏ بأية لغة ولكن أكثر اللغات المستخدمة في هذا المجال انتشاراً هي ++°/° و ۴0۲۲۵٣‏ وبالطبع ۴1 
ا ر ل وع فة عل اة € عبطو ها شن فل اللات سن المطررين على مدى ست رات ركه هذه اللغة دة 
مفسرة أي أنها لا تحتاج إلى عملية معالجة وتحويل إلى ملفات باللغة الطبيعية للآلة حيث تعد هذه ميزة نسبة إلى لغات أخرى مثل ٣‏ 


Fortran ڪ‎ 


تكمن أحد أهم نقاط الضعف في تقنية C61‏ في أن التعامل مع كل طلب يجري على حدى وتجري عملية إنشاء نسخة عن البرنامج 
بالنسبة لكل طلب وتخصيص مساحات للمتحولات خاصة بالنسخة مما يؤدي بالتالي استنزاف المخدم وانخفاض أدائه. 


مثال: 
نورد فيما يلي برنامجاً بلغة ۴٥۲1‏ يقوم بتوليد منصة ۷1 تحتوي بطاقة وحيدة. 


VOUS / OA R7 Bez Û 

print "Content-type: Ttext/VNnd.wap. WINN"? 

GEIRNL FEDL VETSION= NI1. O TT ENCOIINO= ISG EST, 

O ai, <I DOCTTEE ll PUBLIC ¥= IMABTORTM DID WML 1.1/7 ENN 
U MEC PUN o WENE OE LM. OEG DTD AL Aol ML NAS AF 

GEIR uM ay, 

GEIR EAE el Cee LSE 

pI <p>Hello Wireless World!</p>\n"; 

E E Med ML; 

GIIinE <M a, 


Universal Knowledge Solutions s.a.1 
51 


e LS e SS a O O a 


نلاحظ أننا لم نستخدم في هذا البرنامج سوى تعليمة ۲۲1١۲‏ لإرسال خرج من البرنامج حيث يجري إرسال هذا الخرج كاستجابة لطلب 
ما تم إرساله. 


Java servlet 


قامت شركة ۳"”عاءرإءهإءM1‏ «$1 بتقديم تقنية باسم Java ser€‏ لتجاوز عائقين: هما عائق الأداء» وعائق العمل على عدة 
تجري في هذه التقنية عملية ترجمة النص البرمجي إلى رماز من نمط ءلهءع]ر8 والذي تجري ترجمته بدوره باستخدام آلة جافا 
الافتراضية [۷١۷‏ على مخدم الوب. 


تساعد هذه التقنية في نقل النص البرمجي المكتوب بلغة ٤۷16إعء [۷a‏ إلى أية منصة عمل تحوي ۷۷[. أما بالنسبة للأداء فيجري 
إنشاء مسلك تنفيذي (ل11۲2) لكل طلب حيث يعاد استخدام هذه المسالك عند الانتهاء منها مما يوفر الموارد. 


تستخدم ۲٥۲۷1م؛‏ 4۷ز رماز جافا بشكل مشابه لما يحصل في C61‏ لتوليد المكونات ديناميكياً. 


مثال: 


فيما يلي مثال بسيط على استخدام تقنية ٤ع[۷٣إعء۷2ه[.‏ 
سنلاحظ في هذا المثال استخدام أمر 0۲۲م "1 لاستيراد الحزمة الخاصة ب 8۲۷1٤‏ والتي تشكل جزء من إطار العمل الذي تم تطويره 
وفقاً ل .[2٤۴‏ كما سنلاحظ استخدام ١1٤٣إم‏ .اه لإرسال الخرج كاستجابة للمستخدم. 


// Import the required Java libraries 
E E Ig aT 
// Import the required Java Servlet libraries 
Import javax.Servlel.;, 
ImpDoOrt \aVaX.SEeLVIEC NCD, 
public class HelloWorld extends HttpServlet 
1 
public void doGet (HttpServletRequest req, HttpServletResponse 


8 2 O e E E 


res) 

throws ServletException, IOException 

e { 

O res.setContentType ("text/html") ; 

TT: PrintWriter out = res.getWriter (); 

12. OU .GEINTLIR(TETDOCTYPE NEML PUELIC F-7 OPENWAVE/ /DID XIM 
Mobile 1.0//EN\" \" http://www.openwave.com/dtd/xhtml- 
MOS eNO EEE LS) 

18: OUE GE INECIR TERI 

MINS TDEED: WWW .WI. OCG LOS SNEED TMI: lan TENT, 
14 م‎ OE «OE LE LA ( YEME) 2 
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La SUE DE AME IR (LCE ME LEE XHTML Sem le E < E EEL), 
LO OU .DEINLIRN(T</ Hea, 
ls OWE OE LOE LA ( OOS ¢ 

1 o OIE OE ARE URS alem LlEEE C> HELIS TOM MIEEl ESS 
OE LO 1 < O<) 

1 o OU CIINELIR( CBO, 

20 OU. DIINLIR( E NENLZY, 

2 1 

e 


قامت شركة ١"ع)اءإوهإاM Su»‏ بتقديم تقنية باسم ع۷1إعء [4۷a‏ لتجاوز عائقين: هما عائق الأداء» وعائق العمل على عدة 
تجري في هذه التقنية عملية ترجمة النص البرمجي إلى رماز من نمط ءلهءء]ر8 والذي تجري ترجمته بدوره باستخدام آلة جافا 
الافتراضية [۷١۷‏ على مخدم الوب. 


تساعد هذه التقنية في نقل النص البرمجي المكتوب بلغة ٤۷16إعء [۷a‏ إلى أية منصة عمل تحوي ۷۷[. أما بالنسبة للأداء فيجري 
إنشاء مسلك تنفيذي (ل2٠11۲)‏ لكل طلب حيث يعاد استخدام هذه المسالك عند الانتهاء منها مما يوفر الموارد. 


تستخدم ٤٥۷1إعء‏ ۷4ز رماز جافا بشكل مشابه لما يحصل في CK61‏ لتوليد المكونات دیثامیكيا. 


صفحات جافا الخاصة بالمخدم 
JSP‏ 


تعثير 8۴[ الحل السري للمطور الذي يريد الحصول على ميزة الاستقلال عن منصة العمل التي تمنحها 6اة5؛ ولايريد بنفس 
الوقت العمل باستخدام لغة جافا. 


تعتبر 5۶[ تقنية مقادة بالصفحات أي أنه يمكن إدراج منطق العمل المطلوب ضمن سياق لغة التأشير المستخدمة. فالأمور هنا معكوسةء 


إذ عوضاً عن إدراج لغة التأشير ضمن لغة 4۷[ في ا۷16١ءه۷ه[‏ يتم إدراج نصوص برمجية ضمن لغة التأشير . 
يمكن لمحتويات صفحات 8۶[ أن و إلى تصنيفين أساسيين: 


- العناصر: هي عبارة عن تأشيرات شبيهة ب ۷1× تستخدم في السيطرة على سير البرنامج وتحتوي منطق جافا. وهناك 
خمسة أنواع لهذه العناصر هي: 


0 الموجهات : أحد الموجهات هوموجه الصفحة مثلا: 
<SCpags INCOrTL= ava Ull. >‏ 
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التصريحات : كما في حالة التصريح عن متحول من نوع ما2 في هذا المثال 
Date ENeDalê Mew Dale (J;‏ 
التعبيرات: هي عبارة عن إدراج مباشر لقيمة ضمن خرج صفحة 8۲[ 
new java.util.Date() %>‏ =%< 


النصيصات : تعمل بشكل مشابه للتعبيرات ولكنها تستخدم في البنى الأكثر تعقيدا 
%< 
String queryData = request.getQueryString () ;‏ 
OUE .OEIMELN (UAE EACNOC CEN GME J FT CSE VDA E A) f‏ 
>$ 


الأفعال: تستخدم بنية ۷1× للتحكم بمحرك للقيام بأفعال كإدراج نص في صفحة أوتحويل طلب صفحة إلى أخرى 
وأفعال أخرى. 


<jsp:useBean id="inventoryBean" class="sample.InventoryData" /> 


2 معلومات القوالب: هي أي شيء آخر ما عدا العناصر التي تم ذكرها. وعادة ما يهمل محرك 5۶[ هذه المعلومات ويكتفي 


مثال: 


فيما يلي مثال يوضح صفحة 8۶[ تقوم بتولید خر ج بشكل لغة التأشير ا5M]‏ 


1.<%@ page content Type="text/x-hdml"%> 
2 <%@ page language="java"%> 

3. <!=-— String declaration ==> 

4. l SEcino MECN e HN ON E 
د‎ 

6 

8 


SEEIRAS iEem2 193 NO2L; 
SEIR EES AOA O; o> 
<! == HDML Cole t0 display Inventory ligt <> 


GENIM WRG EONS ONS 

0, <display name="item1"> 

O: <action type="accept" task="go" dest="fitem2" label="Skip"> 

TL, <action type="softl" task="go" 

dest="details. jsp ?product_ id=<%=iteml id $%>" label="Details"> 

e Sony IRO DiGiTLal Video Camcorder 

1T </display> 

14: <display name="item2"> 

152 <action type="accept" task="go" dest="fitem3" label="Skip"> 

16 <action type="softl" task="go" 

dest="details. jsp ?product_id=<%=item2_ id %>" label="Details"> 

nN EAC MMDS SL Di1 El @ CEMICOE OEE 

SP LA 

lay name="item3"> 

ion type="accept" task="go" dest="#ffinish" label=" finish"> 
<action type="softl" task="go" 

dest="details. jsp?product_id=<%=item3_id %>" label="Details"> 

2 Sony -DCR-IPTBTI Micto WV Network Handycam 

2 AOL SOLES 
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<display name="finish"> 
<action type="accept" task="return" label="Done"> 
E UAVS SCE ELC E > 
<% 


String username = request.getParameter ("user"); 
OUL .pEIREIN (Than OU EOE VISITING "FEF USseriame)y; 
$> 
VY AMS OLE 
</HDML> 


تعثير 8۴[ الحل السري للمطور الذي يريد الحضول على ميزة الأستقلال عن منصة العمل التي تمتحها ٤6اع5؛‏ ولايريد بنفس 
الوقت العمل باستخدام لغة جافا. 


تعتبر 5۶[ تقنية مقادة بالصفحات أي أنه يمكن إدراج منطق العمل المطلوب ضمن سياق لغة التأشير المستخدمة. فالأمور هنا معكوسةء 
إذ عوضاً عن إدراج لغة التأشير ضمن لغة 4۷[ في ۷16إءءه 4۷[ يتم إدراج نصوص برمجية ضمن لغة التأشير . 


يمكن لمحتویات صفحات 5۶[ أن تصتف إلى تصنيفين أساسيين: 


- العناصر: هي عبارة عن تأشيرات شبيهة ب 11× تستخدم في السيطرة على سير البرنامج وتحتوي منطق جافا. وهناك 
خمسة أنواع لهذه العناصر هي: 
٥ه‏ الموجهات 
ه التصريحات 
ه التعبیرات 
٥ه‏ النصيصات 
ه الأفعال 


5 معلومات القوالب: هي أي شيء آخر ما عدا العناصر التي تم ذكرها. وعادة ما يهمل محرك 5۶[ هذه المعلومات ويكتفي 


تمتلك هذه التقنية قدرات مشابهة لتلك التي تقدمها لغة 5۴[ فهي تقوم بالدمج بين لغة التأشير والنصوص البرمجية والمكونات من طرف 
المخدم في ملف واحد يعطى اللاحقة. ۸8۲ 


لهذه التقنية فعالية أكبر من استخدام C61‏ وهي قادرة على العمل على مخدم 118 وتدعم بيئة المسالك التنفيذية المتعددة. 


تم استخدام هذه التقنية قبل استخدام تقنية 5۲[ وهي أوسع انتشاراً ویمکن استخدامها مع نوعين .VBscripty Java script ٽlغll ja‏ 
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مثال: 


فيما بلي نعيد نفس المتال للنص البرمجي المستخدم في 5۶[ ولكن هذه المرة باستخدام ۸58۶۴. 


<% response.ContentType = "text/vnd.wap.wml" %> 
<%5@ Language=VBScript $%> 
cl variable QeCLAEAELON <> 
TEemMl IIIT ES 
Ttema 10="Il02" > 
TEM. TES 
<xmMI vEerslon=" 1.0" Eencoding=" UTT-ONs 
GC IDOCTIYEE Wl EUSLICG YU A AMEPEORUM/ DID ML 1 IVEY 
e /f/www.wapforum.org/DTD/wml_1.1.xml"> 
O CMI 
10: <card id="item1"> 
I. <do type="accept" label="next"> 
le; <go href="F#fitem2"/> 
Ta < /OOS 
14. <do type="cancel" label="details"> 
154 <ğo href=" detalls.aSsG?producCE 1d=<%=Iteml id $%$5"/> 
1é. < /OOS 
17. <p align="center"><b>Inventory Items</b></p> 
1E < SONVETRVSO DMO EAN VISES CAMCEOEIEE AOS 
e J CE Ol 
208 <card id="item2"> 
2L. <do type="accept" label= 
2 <go href="F#item3"/> 
2. € AOS 
24. <do type="cancel" label="details"> 
298 <ğo href="details.aS6?6rOdUCL 1d=<%=1lem2 1d S5" > 
a € /OOS 
I. <p align="center "><b>Inventory Items</b5></p> 
2 I N EZEM WADE oL Die EAL CAMEO COEE <A 
€ CEES 
<card id="item3"> 
<do type="accept" label="next"> 
<go href="ffinish"/> 
€ /OOS 
<do type="cancel" label="details"> 
<Ggo Brel ="delallS.0SDDIONUCT 1< ITEM) 1G Ss 
< /OOS 
<p align="center "><Dz>Inventory ItEnNSs</5></B> 
<P> SONY. DERT EVEN MMC O MU MNE EWO KE HANOVEAM CO 
€ CAS 
<EdECO CHENIN SMES 
<do type="accept" label="start over"> 
<go href="Ff#fiteml"/> 
</do> 


e E e 
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44. S> VECETOE EO GEE URL PaEame Ee > 

45. <% userName = request. queryString ("user") %> 
46 <p> Thank-you for visiting <%= userName %> </p> 
41. € CE EES 

48. </wml> 


ليست هذه النسخة هي النسخة الأخيرة لهذه التقنية فقطط ظهر إصدار جدید لهذه التقنية يعتمد إطار lلعJan. NET‏ وهویقدم العديد من 
المميزات التي تشمل الأداء والمعيارية. 
قد تكون هذه التقنية الاختيارالأنسب في حالة اعتماد بيئة sسهلمW1‏ كونها تملك أعلى درجة من التكاملية مع نظام التشغيل ومخدم 


الوب وبرمجيات ا0۴ءهإءM‏ الأخرى. 


تمتلك هذه التقنية قدرات مشابهة لتلك التي تقدمها لغة 5۴[ فهي تقوم بالدمج بين لغة التأشير والنصوص البرمجية والمكونات من طرف 
المخدم في ملف واحد يعطى اللاحقة. ۸8۲۴ 


لهذه التقنية فعالية أكبر من استخدام ٥6I‏ وهي قادرة على العمل على مخدم 118 وتدعم بيئة المسالك التنفيذية المتعددة. 


تم استخدام هذه التقنية قبل استخدام تقنية 5۶[ وهي أوسع انتشاراً ويمكن استخدامها مع نوعين من اللغات أمأاءء J4۷2‏ 


اX×M‏ واستخدام صفحات الأنماط ا؟S×‏ 


تقنية توليد المحتوى الأخيرة التي سنتعرف عليها في هذه الجلسة هي تقنية تحويل بيانات لغة التأشير ۷1× باستخدام ملفات صفحات 
الأنماط [؟×. 


نلاحظ في التطور من تقنيات C61‏ واع۷1إعءه۷هز إلى تقنيات ك ۸8۶ و5۶[ أن أحد الأهداف لعملية التطوير تلك كانت فصل 


تحقق صفحات ۷1× وS1؟×‏ هذه الهدف بكفاءة عالية إذا تساعد على فصل كامل بين التقديم والبيانات حيث يتفوق هذا الحل على 
حلول ۸8۶ و5۴۶[ في هذا المجال. 


فعلى سبيل المثال إذا كان لدينا بيانات في صفحة ۷1× ونود الحصول على خرج لهذه البيانات بلغات تأشير مختلفة اWM‏ 
HTML‏ اXH1M‏ يمكننا ببساطة اللجوء إلى إنشاء صفحة 1؟× خاصة بكل واحدة من هذه اللغات. 


مثال: 
فيما يلي مثال عن ملف 1× حیث سنقوم بتقدیم بیانات هذا الملف باستخدام ملف 51×. 
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€ ML WOES LONEN N,“ OHDAS 
<inventory> 


OE OCMUCE LESH IONHS 
<name> 
<manufacturer>Sony</manufacturer> 
<model>TRV30</model> 
</name> 
<description>Digital Video Camcorder</description> 
GALGAL EALSEILLSI OO < O2O</AIGICALIC LLL 
<Tormal Minl DV TormMat Zz 
<OUaNLCIEy, I17 OuanliY 
<price>1699.00</price> 
< PIO 


OE OMUCE 1E NIOAYS 
<name> 
<manufacturer>Hitachi</manufacturer> 
<model>VMD8 75L</model> 
</name> 
<deSCE IGE IGN-DIGIEaAL € Camcorder</ description 
<format>Digital8</format> 
<GUanlilty 24< Guanltllyz> 
OE LEE IS . OOS AOE CES 
<JDIOoluUC > 


OE OCUECE LEY NOSYS 
<name> 
<manufacturer>Sony</manufacturer> 
<model>DCR-IP7BT</model> 
</name> 
<description>Micro MV Network Handycam</description> 
GIMIGLEALSKLLLSGAY x< AOO< dita LSA 
<format>Micro MV</format> 
<OUanNEIEy II<(ouanltity> 
OE LEE Z2LII I< OE LCES 
</BEOUUCL 
<SBEOAUE E O OAS 
<name> 
<manufacturer>JVC</manufacturer> 
<model>GR-DV2000</model> 
</name> 
<description>High-Band Digital Video Camcorder</description> 
GEE EASE LLL LOOOD *« LAOUSLEIGLESALEELL LS 
<Format =MinN1 DV</ Formal > 
<GUanlity >4< GuUanlily> 
<price>1599.00</price> 
O e 


OE OCUECE 1C NODS 
<name> 
<manufacturer>Canon</manufacturer> 
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<model>ES8200V</model> 
</name> 
<description>8 MM Camcorder</description> 
<format>HISMM</format> 
<GUGaNEIEY >< OUANLÎIEY> 
OE LEE: I9 . OOS {E CES 
cJ BIOlUC > 


</inventory> 
يمتل هذا الملف معلومات مستودع يحتوي مجموعة من المنتجات لكل منها وصف» سعر» كمية..إلخ‎ 
.×١۷ا لتشكيل عملية التقديم للبيانات الواردة في ملف‎ ×S1 سنحاول الآن كتابة ملف‎ 


لا بد إضافة السطر الخاص بربط ملف ۷× بملف 1؟× المطلوب لنحصل على النتيجة المطلوبة وتتم هذه العملية بإضافة هذه 
الصيغة إلى بداية ملف ×M1‏ : 


<?xml-stylesheet href="inventory.xsl" type="text/css"?> 


فيما يلي سرد لمحتوى ملف 51× الذي سيقوم بتحويل خر ج بيانات ملف ۷× إلى لغة التأشير اWM‏ 


LO N veRSIOR IL OL 

2. KXSl:Sstylesheet vTersion="l1,0" 

STIRS SES U LINE EO IN N O OE OS O SI ATE AN SEE OEM 

3. <xsl:output method="xml" indent="yes" doctype- 

SySstem=" NEED: /WWW.WADEOFCUM.OFG/DID/WMI_1.1l.xml" doctype-pubDlic="— 
/ /WAPFORUM//DTD WML 1.1//EN" /> 


× بدأنا أولاً بتعريف نوع الوثيقة وسننتقل إلى تعريف قالب سيوضح تشكيل البيانات التي سيتم استخراجها من ملف‎ 
<xsl:template match="inventory"> 
<wml> 
<card 13d="inventory"s> 
<P align="center">Inventory Items</p> 
IS 
<select name="productId" multiple="false"> 
<xsl:apply-templates select="product"/> 
</select> 
</2 
€ CEES 
€ ODI > 
</xsl:template> 


في هذه النقطة ينهي لقاب الخاص بإظهار معلومات المستودع كما تلاحظ قمتا ياستخدام تعبير 51 الخاص بإظها معطلومات العف 
المحددة وهي في Product |iill‏ 


<xSsl:apply-templates select="product"/> 
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الجزء التالي في هذا المثال سيحدد كيفية إظهار معلومات العقدة ل0٣۴‏ وذلك باستخدام تعبير 81× 


<xsl:template match="product"> 


في حين يقوم التعبير 


l:variable name="croduct id"> 
بتعريف متحول باسم 1d_اء ل٠۴۲ ويضع ضمنه القيمة 14 التي يقوم باستيرادها من ملف ×۷× بالتعبير‎ 
:apply-templates select="G@id" /> 


OE SSUES EeEmMOlalte Mal CR SEOGUEE LS 

E axS IE variable Mame=lPEOCUGCE 1> 

1L ¢ <xsl:apply-templates select="G@id" /> 
19 </xsl:variable> 
20 <OpDtION Talue="(SSroOduUCE lO 

21. <xSsl:apply-templates select="name"/> 

- <onevent type="onpick"> 

292 <go href="details.wml"> 

246 <BOSTElEeEId name='produUct 1d" VTalle="(SDTONUCE 1d > 
25. OOS 

20 </onevent> 

1 < AOE LORS 

28. </xsl:template> 

29. <xsl:template match="name"> 

0 <xsl:value-of select="manufacturer"/>-<xsl:value-of 
select="model"/> 

31. </xsl:template> 

32. </xsl:stylesheet> 


تقنية توليد المحتوى الأخيرة التي سنتعرف عليها في هذه الجلسة هي تقنية تحويل بيانات لغة التأشير 11× باستخدام ملفات صفحات 
الأنماط اS؟S×.‏ 
نلاحظ في التطور من تقنيات C61‏ واء۷1إعءه۷هز إلى تقنيات ك ۸8۴ و5۶[ أن أحد الأهداف لعملية التطوير تلك كانت فصل 


تحقق صفحات ۷1× وS1؟×‏ هذه الهدف بكفاءة عالية إذا تساعد على فصل كامل بين التقديم والبيانات حيث يتفوق هذا الحل على 
حلول ۸8۶ و5۴[ في هذا المجال. 


فعلى سبيل المثال إذا كان لدينا بيانات في صفحة 11× ونود الحصول على خرج لهذه البيانات بلغات تأشير مختلفة 
X HTM, WML CHTML‏ يمكننا ببساطة اللجوء إلى إنشاء صفحة 1؟× خاصة بكل واحدة من هذه اللغات. 
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عناصر تحكم نماذج الوب المحمولة 


الكلمات المفتاحية: 


عنصر تحکم»› محمول» لغة تأشيرء تأشيرة» واصفة» خاصة» حدث. 


ملخضص: 
سنتعرف في هذه الجلسة على عناصر تحكم نماذج الوب المحمولة. ستغطي هذه الجلسة العناصر الحاويةء الأساسيةء وتلك المستخدمة 
للأغراض الخاصة. 


أهداف تعليمية: 
يتعرف الطالب في هذا الفصل على: 
٠‏ عناصر تحكم نماذج الوب الحاوية 
٠‏ عناصر تحكم نماذج الوب الأساسية 
٠‏ عناصر تحكم نماذج الوب ذات الأغراض الخاصة. 
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حل مشكلة تطوير الحلول المحمولة 


شاهدنا في الجلسة الماضية العديد من التقنيات واللغات المستخدمة لتطوير الحلول المحمولة. 

ولاحظنا أنه يتوجب على المطور أقلمة المحتوى لينسجم مع التنوع الكبير للتجهيزات ومواصفاتها من حيث مساحة شاشة العرض»› 
والألوانء والمستعرض الصغري المستخدم« وبالتالي اللجوء إلى جملة من لغات التأشير ک—HTML< «CHTML «WML‏ 
....HDML‏ dlخ.‏ 


مع كل هذا الإرباك كيف يمكن للمطور أن يقوم بالعمل على كتابة تطبيقات محمولة بإنتاجية معقولة؟ 


تكمن الإجابة عن هذا السؤال في محاولة جعل التقنية المستخدمة من طرف الزبون غير ذات أهميةء واستخدام كيان وسيط على مخدم 
الوب ليتولى الاهتمام بالمتطلبات الخاصة لكل جهاز زبون بالنيابة عن الجهاز نفسه. 


قدمت ۸8۴.٤١‏ حلا معقولاً يترجم هذه الإجابةء إذ يكفي أن يجري تطوير تطبيق باستخدام ٤6٥.صوه‏ على مخدم وب 118 ليتولى 
إطار العمل N٤1.‏ ضمان تشغيل التطبيق المطوّر على أكثرمن 0 نوع من التجهيزات المحمولة من شركات مختلفة وبمواصفات 
فة كل باستكا فة افير الخاسة ية زم الشاكة اشنا 


لضمان استمرار صلاحية هذا الإطار تقوم )0۴هإء« بتحديثه دوريأ ليشمل التجهيزات المتوفرة في الأسواق. 


فيما يلي شكل يوضح الآلية التجريدية التي تعمل فيها هذه التقنية. 


Internet 
Explorer, 
Palm, etc 


WAP 
Enabled 
Cell Phonê 


Web Forms ASP.NET 
Page Runtime 
I-mode 


Enabled 
Cell Phone 


WAP 2.0 
Enabled 
Cell Phone 


التطوير باستخدام نماذج الوب المحمولة 


تخت مادج الرب المحمواة اذام فحات يقض انظ عن لغة التاشير تى تمتها التجميزات التحمولة الزيائن: 
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يعمل المطور هنا على الواجهة المجردة باستخدام أغراض تمتل المكونات الأساسية التي سيجري إظهارها مثل التأشيرات النصيةء 
ومربعات الإدخال. في حين تقع على عاتق بيئة التشغيل أخذ هذه المكونات المجردة وتحويلها إلى لغة التأشير الخاصة التي يدعمها 
الجهاز المحمول. 


تكون أغراض نماذج الوب المحمولة عبارة عن أغراض برمجية يجري التحكم بتوضعها من خلال استخدام ملف نصي مكتوب بلغة 
XM‏ يقدم هذه الأغراض. 
توفر ۸8۴.N ٤1‏ نماذج وب محمولة مشابهة للنماذج القياسية لتمثيل لكل عنصر من عناصر واجهة المستخدم. 


مثال: 
فيما يلي مثال بسيط يبرز كيفية إظهار عنصر نموذج وب محمول من نوع 61طة1. 
Page Language="vb"‏ @%< 
Inherits="System.Web.UI.MobileControls.MobilePage" $%>‏ 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 
Assembly="System.Web.Mobile" %>‏ 


MONON LEE FOC GVO MLA EUMNAE =3 SEE VEE 
mobi le Label iA labelll EUNaE = GEE VEE elo, 

World</mobile:Label> 

VmMObBM le E OEMS 


استخدمنا في المتال موجه ع۴4 لتحديد اللغة المستخدمة واستخدام الصنف عع 11۴4ا لتوريث الصفحة الحالية. ٹم سجلنا عازامص 
لنتمكن من استخدامها في تتمة الرماز لتشكل سابقة لأسماء عناصر التحكم المحمولة المستخدمة. 

تجري ترجمة هذه الصفحة عند استدعائها لأول مرة ويجري بناء التطبيق ووضعه في الذاكرة الخبيئة بغرض تخديم الطلبات التالية 
لنفس الصفحة. 

عندما يعمل التطبيق يقوم بفحص ترويسة 1۲۲۴ وتحديد نوع الجهاز الذي قام بإرسال الطلب وبالتالي نوع لغة التأشير المطلوبة. 
بعدها يقوم التطبيق بتوليد لغة التأشير المناسبة تجاوباً مع الطلب. 


استخدام نماذج الوب المحمولة 


تعتبر عناصر التحكم المحمولة نمط خاص من عناصر تحكم نماذج الوب العادية. 
يمكننا تقسيم هذه العناصر إلى أصناف نوردها فيما يلي: 


عناصر التحكم الأساسية: هي عبارة عن نسخة من عناصر التحكم المعيارية مثل مربع النص» والوسوم» والصورء وغيرهاء خاصة 
بالتطبيقات المحمولة. 


عناصر تحكم التحقق: تؤمن عملية التحقق من الإدخال بما يشمل نمط البيانات» وتنسيقها أوحتى وجودها. 
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عناصر التحكم الخاصة بالزبون المحمول فقط: تقدم هذه العناصر وظائف يمكن تطبيقها فقط على الزبون المحمول مثل عنصر التحكم 
الخاص بتأسيس مكالمة هانفية. 


عناصر التحكم الخاصة ببنية جهاز مختار محدد: تسمح هذه العناصر بعملية ضبط التطبيق لجهاز معين عبر إعطاء قيمة معينة مثلاً 


لأحد خصائص عنصر التحكم من أجل نوع معين من الأجهزة. 


القوالب: تدعم عناصر التحکم من نو ع ۴0۲۳»› و »۴ane1‏ وListء‏ و 1sاontro Object List‏ ما ندعو ہ بالقو الب (عاھامp٣إ٥۲)‏ حیث 
تستخدم عناصر التحكم تلك عناصر التحكم الخاصة ببنية جهاز محدد لربط قالب محتوى معين بهذا الجهاز. 


قبل البدء باستعراض أهم عناصر التحكم المحمولة المعيارية نوضح بشكل بياني السوية العليا للبنية الهرمية الخاصة بعناصر التحكم 
المحمولة. 
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Systern.Web.ULMonlleCöontrols hãarrıêSþãêcê 


الخصائص العامة لعناصر التحكم المحمولة 


تتحدر أغلب صفوف عناصر تحکم نماذج الوب المحمولة وترث أغلب خصائصها من لص System. Web.U1I.MobileContro1‏ 
الذي يرث بدور ه الصف .System. Web. U1.Contro]‏ 


تحوي جميع عناصر التحكم المحمولة الغرض عy1)؟‏ .015 System. Web. U1.MobileC‌o n)‏ حیث لا یمکن الوصول إلی هذا 
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الغرض مباشرة بل عن طريق خصائص عامة تشير بشكل ضمني إلى قيم خصائص ءارا فعلى سبيل المثال يحوي كل عنصر تحكم 
محمول الخاصة ۴٠١٤‏ والتي تشير إلى خاصة داخلية محتواة في الغرض [را؟ بحيث يمكنك تثبيت أواستخدام قيمة الخاصة الداخلية 


أثناء كتابة البرنامج باستخدام تعبیر من الشکل ٥اھ٤[.۸۲٥۴‏ مثلا. 


على أي حال يمكن تعيين قيم هذه الخصائص مباشرة عن طريق واصفات عنصر التحكم من جهة المخدم بحيث يمكننا كتابة صيغة من 
الشكل: 

moO le: aMobD1 lECOR E Ol 

runat="server" 

OI WOW 

BreakAfter=="{True|False}" 

Font-Name="fontName" 

Font-Size=" {NotSet |Normal | Small | Large}" 

Font-Bold=" {NotSet|False| True}" 

Font-ltalic=" {NotSet |False | True} " 

ForeColor="foregroundColL 

BackColor="backgroundCo 1l 

Alignment=" {NotSet | Left| Center| Right}" 

StyleReference="styleReference"™ 

Visible=" {True|False}" 

Wrapping=" {NotSet |Wrap | NoWrap}" 


cS BHvenNES 

OnDataBinding="EventHandlerMethodName"™ 

OnDisposed="EventHandlerMethodName™ 

OnInit="EventHandlerMethodName" 

OnLoad="EventHandlerMethodName" 
OnPreRender="EventHandlerMethodName" 
OnUnLoad="EventHandlerMethodName" 

</ mobile aMobileControl > 


سنشر ح في الجدول التالي كل من هذه الخصائص باختصار : 

الخاصة القيم اخ 

تحدد اتجاه المحاذاة للعنصر ضمن 
الحاوية الحاليةء وفي حال عدم 
تعيينها تأخذ المحاذاة المحددة في 
الحاوية أوالاتجاه الأيسر في حال 


Alignment.NotSetlLeftlCenterlRight Alignment 


عدم تعيين قيمة للحاوية 
لون الخلفية المستخدم لعنصر 
التحكم. القيمة الافتراضية هي 
Color.Empty‏ 

BreakAfter‏ تحدد إضافة فاصل سطر بعد 
TruelFalse‏ عنصر التحكم. تكون القيمة 


Nonelhexadecimal RGB valueslstandard BackColor 


HTML color identifierslcolor constants 
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الافتراضية هي ٥ںآ"‏ 

زى تر فة اا اجه 
FontSize.NotSetl Normall Smalll Large‏ المحدد حسب مقدرات الجهاز 
الزبون. 


Font.Bold‏ تحدد فيما إذا كان النص سميك أم 
BooleanOption.NotSetlFalselTrue‏ ل 


Font.Size 


Font.Italic‏ تحدد كون الخط مائل. 
BooleanOption.NotSetlFalselTrue‏ 
تحدد اللون المستخدم للنص في 
Nonelhexadecimal RGB valueslstandard‏ عنصر التحکم. 

HTML color identifierslcolor constants‏ في حال تم استخدام "٥08‏ يرث 
النص في العنصر هذه الخاصة من 
العنصر الذي يحويه. 

تستخدم هذه الواصفة في حال 
إعطائها قيمة كمرجع إلى عنصر 
التحكم الذي استخدمّت فيه. 

في حال لم يجر إعطاء قيمة لهذه 


ForeColor 


الخاصة يقوم النظام تلقائياً بوضع 


لا يمكن التصريح عن قيمة هذه 
الخاصة: وتقم عى عانق انط 
مهمة تحديد قيمة لها. تتكون هذه 
E O‏ 
للعنصر 10 تليها قيم الخاصة 15 
لأي عنصر يحتوي هذا العنصر. 

في حال تم إسناد القیمة ع٥۴‏ إلى 
EA E Visible‏ 
على الصفحة كغرض برمجي . 
Wrapping. NotSetlWrapl NoWrap Wrapping‏ تحدد فيما إذا كان النص سيلتف عند 
تخطيه حدود الصفحة أم لا. 


UniqueID‏ قيمة يتم تعيينها من قبل النظام 


تتحدر أغلب صفوف عناصر تحکم نماذج الوب المحمولة وترث أغلب خصائصهھا من |لصڙ System. Web.U1I.MobileContro1‏ 
الذي يرث بدور ہ الصف .System. Web. U1.Contro]‏ 
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تحوي جميع عناصر التحكم المحمولة الغرض System. Web. U1.MobileContro1s.Sty1e‏ حیث لا یمکن الوصول إلى هذا 
الغرض مباشرة بل عن طريق خصائص عامة تشير بشكل ضمني إلى قم خصائص #اراة» فعلى سبيل المثال يحوي كل عنصر تحكم 
محمول الخاصة ۴٠١۲‏ والتي تشير إلى خاصة داخلية محتواة في الغرض هارا بحيث يمكنك تثبيت أواستخدام قيمة الخاصة الداخلية 


أثناء كتابة البرنامج باستخدام تعبیر من الشکل ٥1اھ‏ .۴۵۲ متلا. 
الأحداث العامة لعناصر التحكم المحمولة 
تشترك العديد من عناصر التحكم المحمولة ببعض الأحداث وأهمها: 


الحدث الوصف 
DataBinding‏ يظهر هذا الحدث عند ربط العنصر مع مصدر بيانات. 

Disposed‏ يظهر هذا حدث عند تحرير مساحة الذاكرة التي يحجزها عنصر التحكم. 

يظهر هذا الحدث عندما يجري تأهيل عنصر التحكم وهي المرحلة الأولى في دورة حياة 
عنصر التحكم. 

في هذه المرحلة لا تكون القيمة الخاصة ءه)5 س۷1 متوفرة كذلك لايمكن الوصول 
لأي قيمة من عنصر تحكم آخر من ضمن معالج هذا الحدث. 

يظهر لدى تحميل العنصر ضمن الغرض .Mobil‌e Page‏ 

Load‏ يمكن الوصول إلى قيمة عاه)؟ س۷1 وعناصر التحكم الأخرى من ضمن معالج هذا 
الحدث. 

PreRender‏ يظهر هذا الحدث قبل وضع عنصر التحكم ضمن غرض عع۴2ء 11اه الذي يحويه. 
Unload‏ يظهر هذا الحدث بعد تفريغ عنصر التحكم من الذاكرة. 


تأخذ معالجات الأحداث لجميع هذه الأحداث معاملين الأول من النمط 1ءعزط0 يحدد عنصر التحكم الذي قام بتوليد الحدث والثاني من 
نمط ۷۸۲۸۲8۶ System .٤‏ يحدد معلومات عن الحدث نفسه. 

EventHandlerMethodname (Object sender, EventArgs e) 
لتحديد اسم الطريقة التي سيتم تشغيلها عند إطلاق الحدث فيمكننا استخدام الصيغة.‎ 


<mobile:aMobileControl 
runat="server" 
a 
OnLoad="methodName™"™ 


حيث يجري تشغيل الطريقة عمصهN ٣٧‏ ه0طع" عند إطلاق الحدث 024م0. 
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عناصر التحكم الحاوية 


يطلق هذا الاسم على عناصر التحكم التي تمكننا من تجميع عناصر التحكم الأخرى. أهم تلك العناصر عنصر التحكم ۴٥۲۳‏ الذي 
يساعد في عملية تجميع عناصر التحكم الأخرى ضمن وحدات برمجية. أما العنصر الثاني فهو عنصر التحكم ٥1‏ ه۴ الذي يساعد في 


ترث العناصر التي توضع ضمن عنصر التحکم 1٥ہھ۴‏ أو ۴۵۲۳ خصائص هذا العنصر المحدد للنمط عارا؟ إلا إِذا تم تحدید قیم 
خاصة لعناصر التحكم بصورة إفرادية. 


غالباً ما تمثل عناصر تحكم ۴261 آلية عملية لتطبيق نمط محدد على مجموعة من عناصر التحكم التي يحتويها. 


فيما يلي الشكل البياني الذي يوضح البنية الهرمية للعناصر ۴٥۲۳‏ و1ع,Pa:‏ 


System. Web.Ul. MobileControls 
namêspacê 


قواعد الاحتواء: 

توفر عناصر التحكم الحاوية آلية فعالة لإعطاء هيكلية لتطبيق الوب» لذلك لا بد من الإلمام بشكل جيد بقواعد الاحتواء المتبادلة بين هذه 
العناصر وعناصر التحكم الأخرى. 

للاختصار ولوضوح أكبر نورد الشكل البياني الذي يوضح قواعد الاحتواء المتبادلة بين عناصر التحكم: 
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MobilePage class (or descendant) 


Panel control Panel control 


Other mobile control Panel control 

Other mobile control Other mobile control 
Panel control 

Other mobile control Other mobile control 

Other mobile control Other mobile control 


MobilePage class (or descendant) MobilePage class (or descendant) 


Form control 


Form control 


¥ 


¥ 


Form control 


عناصر التحكم الحاوية 
- عنصر التحکم ۴٥٣٣‏ - 


يعتبر عنصر التحکم ۴٥۲۳‏ العنصر الخارجي ضمن غرض عع۲ء اہ حیث تحتاج صفحة نماذج الوب إلى عنصر تحکم ۴٥۲٣۳‏ 
واحد على الأقل لاحتواء عناصر التحكم الأخرى. 


بالإضافة إلى قدرة عنصر التحکم ۴٥۲۳‏ على احتواء عناصر التحکم الأخریء یستطیع عنصر التحکم ۴٥٣٣‏ احتواء النص خارج 
عناصر التحكم المحمولة حيث يمكن تنسيق هذا النص باستخدام التأشيرات الخاصة بالتتسيق مثل <م/><مp>»‏ </51>» <ط/><ط>» 


9995 


<a href= 
ملاحظة هامة: يمكن استخدام تأشيرات التنسيق تللك فقط للنص الحر ضمن عنصر التحكم ۴0۲۳ و لايمكن استخدامها بالنسبة للنصوص‎ 
ضمن عناصر التحكم المحمولة الأخرى» أي أن الصيغة التالية لن تكون صحيحة.‎ 


TOOL LE ES LEOOSL EUNICE ICC UELVUS<OSHELLEG WOE LOS /OS< AMOOLLE SAO 


></a> «<i></i> 
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نورد فيما يلي صيغة تحتوي معظم الخاصات المتعلقة بعنصر التحکم :۴0٥۲٣۳١‏ 


<mMmObDi le :EOEM 

runat="server" 

1d="id" 

Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small | Large}" 
Font-Bold=" {NotSet|False| True}" 

HORNE TEaAlI C=" NOESEE Eal se | TEUe | 
ForeColor="foregroundColor™ 

Balek COI OG "Dae RGEOURACO LOE 
Alignment=" {NotSet | Left | Center| Right}" 
StyleReference="styleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap | NoWrap}" 


e E OR 
Method=" {Post | Get }" 
OnActivate="onActivateHandler" 
OnDeactivate="onDeactivateHandler" 
Paginate="{True|False}" 
PagerStyle-NextPageText="text" 
PagerStyle-PageLabel="text" 
PagerStyle-StyleReference="styleReference™ 
iT E E — iE O II E LON > 

Cı LE COMEEOLS 

</mobile :Form> 


وسنشرح فيما يلي الخصائص التي تميز عنصر التحكم هذا: 

الخاصة النمط الضف 

يمثل عنوان ال 10۸1 الذي سيجري إرسال محتوى النموذج إليه باستخدام 
إحدی الطریقتین ۴081 أُر1٤6.‏ 

في حال لم يجر تعيين قيمة لهذه الخاصةء يجري إرسال النموذج إلى نفس 
عنوان 01ا للصفحة الحالية. 

تمكن هذه الخاصة من السماح لعنصر تحكم واحد على النموذج من أن يتم 
Control | ControlToPaginate‏ تحويله إلى عدة صفحات حتى وإن كانت قيمة الخاصة ءا1«2عه۴ في عنصر 
تحكم النموذج تساوي القيمة عءاه۴. 

تقوم هذه الخاصة بإعادة دليل الصفحة الحالية في حالة حدوث عملية تقسيم إلى 
صفحات. 


Action 


Integer CurrentPage 


System.Web.UI. 
تحدد الطريقة المستخدمة لإرسال طلب 11۲۴ حيث تأخذ إحدى القيمتين‎ | Mobile Contos. 


FormMethod.Post أما القيمة الافتر اضية في‎ Gمtوأ‎ Pt FormMethod 
Post | Get 
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تعيد العدد الكلي للصفحات التي تم تقسيم النموذج إليها في حال حدوث هذه 


Integer PageCount‏ العملية. 


System.Web.UI.‏ تقوم بتحديد أوبإعادة قيمة الغرض عارا؟5ععه الذي يحدد النص الذي 


PagerStyle‏ .sاMobileContro‏ سيجري إظهاره. 

(Next — Previous) يقوم النظام بصورة تلقائية بتوليد وصلات‎ PagerStyle 

True | False Paginate‏ تحدد هذه القيمة المنطقية وجوب السماح بتحويل النموذج إلى أكثر من صفحة. 
يمثل عنوان النموذج ويظهر عادة في أعلى الصفحة أوفي أماكن أخرى اعتمادا 


Strin Title 
على المستعرض‎ 


ملاحظة: في الحالة التلقائية لا يسمح عنصر تحكم النموذج بتقسيم الخرج إلى صفحات لذلك قد نحصل عند تجريب تطبيقاتنا على 
أخطاء سببها عدم دعم الجهاز لأسلوب عرض الخرج. 


یعتبر عنصر التحکم ۴٥۲۳‏ العنصر الخارجي ضمن غرض ٥۴ء‏ اہ حیث تحتاج صفحة نماذج الوب إلی عنصر تحکم ۴٥۲٣۳‏ 
واحد على الأقل لاحتواء عناصر التحكم الأخرى. 


بالإضافة إلى قدرة عنصر التحكم Form‏ لئ احتواء عناصر التحكم الأخرىء يستطیع عنصر التحكم Form‏ احتواء النلص خارج 
عناصر التحكم المحمولة حيث يمكن تنسيق هذا النص باستخدام التأشيرات الخاصة بالتنسيق 


عناصر التحكم الحاوية 
- عنصر التحکم ۴٥٣٣‏ - 


يمتلك عنصر التحكم ۴۳ مجموعة من الأحداث تتضمن Deactivate ›»Ac)1v ae‏ inateعPa‏ ترتبط بتنشيط وإيقاف النموذج 
وكذلك بعملية التقسيم إلى صفحات. 


كما يدعم عنصر تحكم النموذج إمكانية الربط بllتقو‏ lلب .Script Template s «FooterTemplate s «HeaderTemplate‏ 
فيما يلي ندرج مثال بسيط عن كيفية استخدام عنصر تحكم النموذج المحمول. 


يقوم هذا المثال بإنشاء نموذجين والسماح بالحركة بينهما باستخدام عنصر تحكم )ہ1 


<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls"™ 
Assembly="System.Web.Mobile" %> 

<%5@ Page language="c#" 

Inherits="System.Web.UI.MobileControls.MobilePage" $%> 


<mo bm Ke E OGM AA LEORMI GUNE SEVER 
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: Label iOS lT eabe LIL GUNA Seve 


Labels 
:Link id="Link1l" runat="server" NavigateUrl="#EForm2"> 


Tmo eR RK 
< /mobi le : Eorm> 


<mMOON le EOE 14A HOEMZL EUNAE= SEVER LS 
oz. 

i ERew, YOU made EI I, 
COS 
GOES 
<o ler Label MI Tabe l2" EUNAE >L SEVERELY 

HEOEM 

</mobile:Label> 

</mobile:Form> 


يظهر خرج هذا البرنامج على المحاكي الخاص بنوكيا على الشكل: 
J simulator simulator‏ 


يمتلك عنصر التحكم ۴٥۲۳‏ مجموعة من الأحداث تتضمن ۸1۷2ء ›Deac)ivae‏ inateعمP‏ ترتبط بتنشيط وإيقاف النموذج 
ركلك اة التفي إلى فهاة: 


كما يدعم عنصر تحكم النموذج إمكانية الربط بلقو الب .ScriptTemplate s «FooterTemplate , «HeaderTemplate‏ 


عناصر التحكم الحاوية 
- عنصر التحکم [اeمر۴a‏ - 


لا يمتلك عنصر التحكم 1٥«ه۴‏ أي خرج مرئي ولكنه يُستخدم للتجميع المنطقي لعناصر التحكم المحمولة الأخرى (عدا عنصر تحكم 
النموذج). إذ يمكن لعنصر تحكم نموذج أن يحتوي عنصر تحكم ۴2,61 واحد أوأكثر» كذلك يمكن لعنصر ۶4١٥1‏ أن يحتوي عنصر 
تحکم ۴a1‏ أو أکثر. 
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تجري كتابة النص البرمجي لعنصر تحكم 1ع٫ه۴‏ كما يلي : 


<mobile:Panel 

runat="server" 

1d="id" 

BreakAfter==" {True|False}" 
Font-Name="fontName" 
Font-Size=" {NotSet | Normal | Small | Large} " 
Font-Bold=" {NotSet|False| True}" 
Font-Italic="{NotSet |False | True}" 
ForeColor="foregroundColL 
BackColor="backgroundCo 1l 
lignment=" {NotSet | Left | Center| Right}" 
leReference="styleReference"™ 

Lble=" {True|False}" 
Wrapping=" {NotSet |Wrap |NoWrap}" 


Paginate="{True|False}" > 
CML LEO COMEEOLS 
</mobile:Panel> 


يجري حصر عناصر التحكم الأخرى المراد وضعها ضمن عنصر تحكم 1٥.ة۴‏ هذا بين تأشيرتي: 


<mobile :Banel></mobilée :Panel> 


يمكننا من النص البرمجي السابق الانتباه إلى أن عنصر التحكم ۴4,٥1‏ يقدم الخاصة ء2”آعه۴ كخاصة إضافية عمًَا ذكرناه في 
خصائص عناصر التحكم. 


ق هذ كاف نرك زفق التقل الل هرورة مار غ2 القافر اسر كين فصر كك اوو في س ال 
(إن أمكن). 

يُظهر المتال التالي أربعة عناصر تحكم 1ءط14. يتوضع إثنان منهما ضمن عنصر تحكم ۴2٥1‏ الذي يحتوي بدوره عنصر تحكم 
1 آخر يحتوي عنصري تحكم 1٥ھ[‏ الباقیین: 


<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 

<%5@ Page language="c#" 

Inherits="System.Web.UI.MobileControls.MobilePage" $%> 


KE EOE MA HOMIE CUMA ES SERVERS 
<mobile:Panel id="Panel1" 
i WAA IE 1 SEE EEL 
HORE EBOISG uel > 
<mobile:Label id="Label1" runat="server"> 
Tabel l1 Eeanel 1 
</mobile:Label> 
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<mobile:Label id="Label2" runat="server"> 
Label Z2 Eanel 1 
</mobile:Label> 
<mobile:Panel id="Panel2" 
E UAE SEE VOR 
EOE TEALI CEN EUE LS 
MOINS LE ¢ Lale lL 1E NSE TUNAES  SCEVEGLY 
Label 1 Panel 
</mobile:Label> 
MOND JE ¢ Lale lL 1G LAN TUE —W EAE MEI YS 
Label 2 Panel 
</mobile:Label> 
</mobile:Panel> 
</mobile:Panel> 
< /mObi le : EOrM> 


نلاحظ هنا عملية الوراثة لنمط الخط المستخدم من عنصر التحكم ۴4"٥1‏ إلى عناصر التحكم 1ع طج1 المحتواة ضمنه. 


يظهر خرج هذا البرنامج على المحاكي الخاص بنوكيا على الشكل: 


لاتا 


Label 1 Panel 1 
Label A Panel 1 
{abel 1 Panel 2 
{abel 2 Papel 2 


لا يمتلك عنصر التحكم 1٥«ه۶‏ أي خرج مرئي ولكنه يُستخدم للتجميع المنطقي لعناصر التحكم المحمولة الأخرى (عدا عنصر تحكم 
النموذج). إذ يمكن لعنصر تحكم نموذج أن يحتوي عنصر تحكم 61«ة۴ واحد أوأكثر» كذلك يمكن لعنصر ۶4١٥1‏ أن يحتوي عنصر 
تحكم 1٥"ھ۶‏ أوأكثر. 

عناصر التحكم الأساسية 


سنتعرف في هذه الجزء على عناصر التحكم الأساسية وهي تتضمن تلك المسؤولة عن الملاحة ضمن المستعرض كعنصر تحكم 
0mmand‏ وعنصر تحكم Kہ11.‏ سنتعرف كذلك على عناصر التحكم الخاصة بالخرج مٿل عناصر ت>pĞم «Label‏ وTextView«‏ 
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و2[ بالإضافة إلى عنصر تحكم الإدخال المباشر ×80)×١ه1.‏ 


عنصر التحكم :Com mand‏ 
يسمح عنصر التحكم هذا بعملية إرسال البيانات إلى المخدم. تختلف الطريقة التي يجري فيها إظهار عنصر التحكم هذا على منصات 
العمل المختلفة وهوعادة ما يظهر بشكل زر في المستعرضات التي تدعم خرج لغة التأشير ا١1۲‏ أويتم إظهاره كرابط في 

.W M1 مستعرضات‎ 


فيما يلي النص البرمجي الذي يوضح الخصائص والأحداث التي يزودها عنصر التحكم هذا: 


<mobi le: Command 

runat="server" 

1d=" id" 

Alignment=" {NotSet | Left | Centre| Right }" 
Bae KCl O = Dale IEO URAC O U OE 

BE e ARA Ee = Ee EASE 
Font-Bold="{NotSet|False| True}" 

EOnNE TEalICE= "I NOoOESEeE | Eal se | IE Ue} 
Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small | Large}" 
ForeColor="foregroundColor"™ 
StyleReference="StyleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap |NoWrap}" 


CausesValidation=" {True|False}" 
CommandArgument="commandArgument"™ 
CommandName="commandName" 
ImageUrl="softkeyLabel" 
ORCL TEKRS LEN CEE EVERE N ARGS 
OnItemCommand="commandEventhandler" 
SoftkeyLabel="softkeyLabel" 
Text="Text"> 

TextContent 

</mobile :Command> 


يرث عنصر التحكم ل٣2٣‏ ه٥‏ الخصائص والأحداث المشتركة من الصف ٠٣٤١١1‏ ٣1اه‏ لذلك سنورد فيما يلي فقط الخصائص 
والأحداث الإضافية التي يقدمها عنصر التحكم هذا: 

الخاصة أوالحدث النمط الوصف 
TruelFalse CauseValidation‏ تفيد هذه الخاصة فقط في حال احتوى النموذج الذي يحتوي عنصر 
التحكم على عناصر تحكم خاصة بالتحقق مثل 
«Range Validator<Custom V alidator< Compare Validator‏ 
.RequieredFiel Validator‏ 
عادة ما يتم إطلاق عناصر التحكم الخاصة بالتحقق عند إرسال 
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CommandName 


CommandArgument 


Format 


ImageUrl 


Clic) الحدث‎ 


ItemComnand ثiدحنا‎ 


SoftKeyLabel 


System.Web.UI. 
MobileControls. 
CommandFormat 


Button | Link 
String 


اسم طريقة معالج الحدث 


اسم طريقة معالج الحدث 


يوضح المثال البسيط التالي عمل عنصر التحكم هذا: 


البيانات بضغط زر ٥٥۳٣۵٣4‏ ولكن في الكثير من الأحيان لا 
کون هذا انطو با :كنا فوالحال عنك اتخداء زر 
mma‏ لإظهار لوحة خاصة باختيار التاريخ ضمن نموذج 
لإنخال. امات التخصة: 

تعطي قيمة الخاصة 4N 4me‏ ”ةمه التابعة للغرض 

ئ8 anEvenصmص‏ الذي يجري تسليمه لمعالج الأحداث 
OnltemCommand‏ 

تعطي قيمة الخاصة Command Agu ne1٤‏ التابعة للغرض 
ئ8 andEvenصmص‏ الذي يجري تسليمه لمعالج الأحداث 
OnltemCommand‏ 


تعطي الشكل الذي سيتم تحويل شكل عنصر التحكم إليه فإما أن يأخذ 
شکل زر أوشکل رابط. 

لا تعمل هذه الخاصة إلا في حالة المستعرضات التي تدعم 
JavaScript‏ 

عند تقدیم عنصر التحکم C0100 02٥0‏ کزر» یمکن عند تحدید هذه 
الخاصة أن يجري إظهار صورة زر على التجهيزات التي تدعم 
اأضنوز: 

يعطي اسم طريقة معالج الحدث. فعند ضغط المستخدم على عنصر 
التحكم dأ«مدصص٣ه‏ تجري إعادة عنصر التحكم إلى المخدم» ويقوم 
محرك زمن التشغيل باستدعاء الطريقة المحددة كقيمة لهذه الخاصة. 


كما هي الحال مع حدث عء1ا€» يحدد هذا الحدث طريقة معالج 
الحدث. 


يمكن في هذا الحدث» إدراج أية قيمة مرغوبة ضمن العامل 
Command EventArgs‏ وذلك باستخدام الخاصتین 


CommandArgument ş CommandName 

تقدم بعض التجهيزات المحمولة كالهواتف المحمولة إمكانية 
الاتستخدام بأزرار برمجيةء تسمح هذه الخاصة بتغيير النص الذي 
يظهر ضمن هذه الأزرار. تكون القيمة التلقائية للأزرار البرمجية 
هي 60. 

يمكن تحديد النص الذي سيجري إظهاره لعنصر التحكم هذا إما 
بوضع هذا النص ضمن التأشيرة الخاصة بعنصر التحكم أوبإسناد 
القيمة المطلوبة. 
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<%5@ Register TagPrefix="mobi le" 

Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 

<%5@ Page language="c#" Codebehind="CommandExample.aspx.cs" 

Inherits="MSPress.MobWeb.CmdEx.MyWebForm" %> 


MOO le :EOEM AE HORM. EUNaAE = SCER VERS 
<mobile:Command id="Commandl"™" runat="server" CommandName="RED" 
ItemCommand="Command_SelectEvent" BackColor="Red"> 


</mobile:Command> 
<mobile:Command id="Command2" runat="server" CommandName=" BLUE" 
OnItemCommand="Command_SelectEvent" BackColor="Blue" 
ForeColor="White"> 
Blue 
</mobile:Command> 
<mMOoOSN le: ConNmMand id Command FUNaAE- SEVE COMMARNGNaAME = CREEL 
OnIEemcommand= Command Select EvenEl. BacGkKCOl OE Lime l> 
Green 
</mobile :Command> 
<mobile:Label id="Message" runat="server"></mobile:Label> 
</mobile:Form> 


وفيما يلي النص البرمجي كء.×5pھ.p1e‏ ص Command ٤xa‏ المكتوب بلغة #°: 


using System; 
using System.Web.UI.WebControls; 


namespace MSPress.MobWeb. CmdEx 
{ 
public class MyWebForm 
System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web.UI.MobileControls.Label Message; 


protected void Command_SelectEvent ( 
Object sender, CommandEventArgs e) 
{ 
1f (e.CommandName=="RED" ) 
Message.Text="You selected the Red option"; 
else 1f (e.CommandName==" BLUE") 
Message.Text="You selected the Blue option"; 


lse 
// Catchall case 
Message.Text="You selected the Green option"; 
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سنتعرف في هذه الجزء على عناصر التحكم الأساسية وهي تتضمن تلك المسؤولة عن الملاحة ضمن المستعرض كعنصر تحكم 
andصmصmدC‏ وعنصر تحكم «٤‏ 11. سنتعرف كذلك على عناصر التحكم الخاصة بالخرج مثل عناصر تحكم «TextViewg «Label‏ 
و2[ بالإضافة إلى عنصر تحكم الإدخال المباشر ×80)×ع1. 


عنصر التحكم :Com mand‏ 
يسمح عنصر التحكم هذا بعملية إرسال البيانات إلى المخدم. تختلف الطريقة التي يجري فيها إظهار عنصر التحكم هذا على منصات 
العمل المختلفة وهوعادة ما يظهر بشكل زر في المستعرضات التي تدعم خرج لغة التأشير ا١1۲‏ أويتم إظهاره كرابط في 

. M1 مستعرضات‎ 

عناصر التحكم الأساسية 
عنصر تحکم ٥ع2"]:‏ 
يساعد هذا العنصر في إظهار ملفات صور. يشكل هذا العنصر مشكلة بالنسبة للمطور نظرأ للاختلاف والتفاوت بين تنسيقات ملفات 
الصور التي تدعمها التجهيزات المحمولة المختلفةء إضافة إلى الاختلاف بين قدرات عرضشاشات هذه التجهيزات. 
لذا يجب تأمين ملف الصورة بأكثر من تنسيق وتحديد استجابة كل نوع من التجهيزات لإرسال التنسيق المناسب حسب الجهاز الذي قام 
بإرسال الطلب. 


ملاحظة : يمكن تجنب هذه الطريقة باستخدام عنصر التحكم الخاص المسمى عع4”٠1ءاص‏ هر الذي يقوم تلقائياً بتحویل تنسيق 
الصورة إلى التنسيق المناسب حيث سنأتي على شرح عنصر التحكم هذا بالتفصيل لاحقا. 


فيما يلي النص البرمجي الذي يوضح الخصائص والأحداث التي يقدمها عنصر التحكم هذا: 
<mobi le: Image‏ 

runat="server" 

d=" i 0‏ ت 

Alignment=" {NotSet | Left| Centre| Right}" 

Eale KEC oO = "DaCEKGEOU RACES OE 

BreakAfter=="{True|False}" 

Font-Bold=" {NotSet|False| True}" 

EORE TlEaAlIE= INOESEE Eal se | IEUe 

Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small | Large} " 
ForeColor="foregroundColor"™ 
leReference="StyleReference" 

lLble=" {True|False}" 
ing="{NotSet|Wrap|NoWrap}" 


lternateText="AltText" 
ImageUrl="master ImageSource" 
NavigateUrl="targetURL" 
SoftkeyLabel="softkeyLabel"> 


a 


Optional DeviceSpecific/Choice construct here. 


</mobile: Image> 
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إضافة إلى الخصائص العامة التي سبق لنا الحديث عنهاء يقدم عنصر التحكم هذا مجموعة من الخصائص الإضافية نذكر أهمها: 


القاضة نوعها الوضبت 
يحدد النص الذي سيظهر على التجهيزات التي لا تدعم إظهار 
الور عو كا عن الضورة المستخدمة كما تخرد مكان 
الصورة على المستعرض بانتظار تحميل هذه الصورة من 
المخدم. 

تحدد مصدر ملف الصورة المطلوب استخدامها. يمكننا هنا 
ImageURL‏ استخدام المسار النسبي أوالمسار المطلق حسب موقع ملف 
الصورة المراد إظهارها. 

إذا قمنا باستخدام هذه الخاصة تتحول الصورة إلى رابطء 
ويمثل العنوان 0R‏ ء)عه اه" العنوان الذي سيتم الانتقال 
NaviagteURL‏ إليه عند الضغط على رابط الصورة. 

في حال بدء هذه القيمة بالإشارة (#) تجري ترجمة العنوان 
كقيمة 10 لعنصر تحكم ۴١۲۳‏ في نفس الصفحة. 


Alternate Text 


من أهم أنماط ملفات الصور التي يدعمها عنصر التحكم هذا: نع ومصطسw»‏ وعمزء وعہ۴. 


عناصر التحكم الأساسية 


استخدام عنصر التحكم eعه"]:‏ 

ذكرتا مسقا بأنة يمكن استخذام الصور عبر تحدية ملف الصورة الموافق التشسيق الذي يذعمة الجهاز. 

يبين المثال التالي كيفية تطبيق التأشيرة <عاfذءمم؟ءء‏ 0۷> مع التأشيرة <عءزمطء> ضمن عنصر التحكم 1488 لاستخدام 
تنسیقات صور مختلفة بحسب دعم الجهاز لهذا التنسيق: 


<%5@ Page Inherits="System.Web.UI.MobileControls.MobilePage™ 
Language="c#" %> 

<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


<mobile:Form runat="server"> 
<mobile: Image runat="server" id="Image1l" 
AlternateText="Northwind Corp."> 
<DeviceSpecific> 
<Choice Filler ISHIMLST 
ImageUrl="Northwind.Gif"/> 
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<Choice Filter="isWML11™ 
ImageUrl="Northwind.wbmp"/> 
</DeviceSpecific> 
</mobile: Image> 
</mobile:Form> 


لا بد لإتمام هذا العمل تعريف الفلاتر الستخدمة ضمن ملف الإعداد عاگصهء.اء۷ والذي سيحتوي النص التالي: 


€ N wer EN OY N “OE Eneoeln Me UE E MY 
CONTI UTA 
<Ssystem.web> 
<deviceFilters> 
E MarKEUP Lengua deSs > 
<filter name="isHTML32" 
compare="preferredRenderingType" argument="html32" /> 
<filter name="isWML11" 
compare="preferredRenderingType" argument="wml11" /> 
</deviceFilters> 
</system.web> 
< CORE LO UE AE LORS 


استخدام الصور والرموز المبيتة: 


يعطي عنصر تحكم #عه"[ الخاصة 111ء1042 قيمة تشير إلى رمز أوصورة مبيتة ضمن الجهاز المحمول. ترقم هذه الرموز عادة 
ابتداءاً من 01:0000ط”ر؟ أوتأخذ في بعض أنواع التجهيزات الصيغة 01:×00طر؟ حيث يمكن أن يكون × أحد الأحرف 6 أُوع 
أو۴» أما 00 فيعبر عن رقم ست عشري. 

كما يمكن استخدام اسم الرمز بالشكل رلuه!1ء:01طدمر؟‏ حيث رلسهاء هنا اسم الرمز المعبر عن الجوالغائم. يشبه المثال التالي المثال 
السابق في هذه الشريحة ولكنه يستخدم رمز yإuه!اSymb01:c:‏ 


<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 

<%5@ Page Inherits="System.Web.UI.MobileControls.MobilePage™ 


Language="c#" %> 


<mobile:Form runat="server"> 
<mobile:Label runat="server"> 
The Weather today will be...</mobile:Label> 
<mobile: Image runat="server" 
AlternateText="Cloudy!"™ 
ImageUrl="cloudy. jpo"> 
<DeviceSpecific> 
<Cholce ImageUrl="symbol:cloud" Filter="iSsUPAxXT> 
</Choice> 
</DeviceSpecific> 
</mobile: Image> 
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IOS 
<mobile: Image runat="server" 
AlternateText="GoTo MSN" 
ImageUrl="MSNlogosmall.gif"™ 
NaviGalteUr lE"NEEp:7/MOBDIlE. MSN. COM> 
<DeviceSpecific> 
<Choicê ImageUrl1="MSNlogo.gif" Filter="jisPockeltIlE"s 
</Choice> 
</DeviceSpecific> 
</mobile: Image> 
</mobile:Form> 


هناك ضرورة لاستخدام ملف عاگمصهء.اء۷ لتعريف الفلاتر: 
ENN ere E1 OMS N OY EceOON Me UIE E OY‏ 
<CORT I UrEaALIOR‏ 
<system.web>‏ 
<deviceFilters>‏ 
Device Browsers -=->‏ -—-!< 
<filter name="isGoAmerica"‏ 
compare="browser" argument="Go.Web" />‏ 
<filter name="isMME" compare="browser"‏ 
E CENE MN CE OSOEL MOO LE ol OEEEN 1‏ 
<filter name="isMyPalm" compare="bþbrowser" argument="MyPalm" />‏ 
<filter name="isPocketIE" compare="bþbrowser" argument="Pocket‏ 
TE‏ 
<filter name="isUP3x"‏ 
compare="type" argument="Phone.com 3.x Browser" />‏ 
<filter name="isUP4x"‏ 
compare="type" argument="Phone.com 4.x Browser" />‏ 
</deviceFilters>‏ 
</system.web>‏ 
</CONEIGUEaEIONS‏ 


سيكون خر ج هذا البرنامج كالتالي بحسب المستعرض: 


El Internet Explorer 17:12 ۳ nn ا٥ا‎ × 


http: ftestmcfimageexamplejimage ” 


The Weather taday wil be... 


msn 


Yi Tools ا‎ 
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استخدام عنصر التحكم geھ"]:‏ 
ذكرنا مسبقاً بأنه يمكن استخدام الصور عبر تحديد ملف الصورة الموافق للتنسيق الذي يدغمه الجهاز. 


استخدام الصور والرموز المبيتة: 

يعطي عنصر تحكم معه"! الخاصة 011ء142 قيمة تشير إلى رمز أوصورة مبيتة ضمن الجهاز المحمول. ترقم هذه الرموز عادة 
ابتداءاً من 01:0000طا $ أوتأخذ في بعض أنواع التجهيزات الصيغة 01:×00ط۳ر؟ حيث يمكن أن يكون × أحد الأحرف 6 أُو٤‏ 
أو۴» أما 00 فيعبر عن رقم ست عشري. 


عناصر التحكم الأساسية 
عنصر التحکم [eطھ]:‏ 
يساعد عنصر التحكم هذا في إظهار نص قصير مخصص للقراءة على خرج شاشة الجهاز المحمول. 
فيما يلي الصيغة المستخدمة لإدراج عنصر التحكم هذا. وقد تم فيها توضيح القيم التي تأخذها الخصائص المختلفة : 
<mobile: Label‏ 
runat="server"‏ 
1d=" id"‏ 
Alignment=" {NotSet | Left| Centre| Right}"‏ 
Baek Colo — "DaCKRGEOURAEO LOE‏ 
BEE ARA Ee = EU eE Ea SEL‏ 
Font-Bold="{NotSet|False| True}"‏ 
Font-ltalic="{NotSet |False | True} "‏ 
Font-Name="fontName"‏ 
Font-Size=" {NotSet | Normal | Small | Large} "‏ 
HOEECEOlOE= E OFEGE OURACO LOE‏ 
StyleReference="StyleReference"™‏ 
Visible=" {True|False}"‏ 
Wrapping=" {NotSet |Wrap | NoWrap}"‏ 


MEE NEE US 
TextContent 
</mobile:Label> 


لا يقدم عنصر التحكم سوى خاصة واحدة هي ٠٠×٤‏ إضافة إلى الخصائص المشتركة الموضحة سابقاًء تساعد هذه الخاصة في تحديد 


قيمة إلى النص المراد إظهاره ضمن عنصر التحكم هذا تعتبر هذه الطريقة بديلا لوضع النص ضمن تأشيرة 
<mobile:Label></mobile:Label>‏ 


: المثال التالي يوضح استخدام عنصر التحكم هذا‎ 
<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 
<%5@ Page Inherits="MSPress.MobWeb.LbDLEx.MyWebForm" 
AutoEventWireup="False" 
Language="c#" CodeBehind="LabelExample.aspx.cs" %> 
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MOOR KE SE OEM EUMNAE= SERVE MG OM LS 
MOO ME Label ia FaDel lL FUNA E SCE 
StyleReference="title" 
Alignment="Center"> 
CEnEer ed MENE 
</mobile:Label> 
<mobile:Label id="Label2" runat="server"></mobile:Label> 
SV mMOBM NE E E OSEMS 


أُما النص البرمجي الذي سيتم استخدامه في الخلفية والذي يأخذ الاسم كء.×مءه.عامص18xamءطه.‏ النص هنا يقوم بتعيين قيمة النص 
لعنصر التحكم 1.4٥12‏ عند تحميل الصفحة. 


using System; 
using System.Web.UI.MobileControls; 


namespace MSPress.MobWeb.LbLEx 


{ 
public class MyWebForm : System.Web.UI.MobileControls.MobilePage 


1 
protected System.Web.UI.MobileControls.Label Label2; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


} 


private void InitializeComponent () 


{ 
this.Load += new System.EventHandler (this.Page_Load); 


} 


protected void Page_Load(Object sender, EventArgs e) 
{ 

abel 2 .TexE > IMIS WQS Se iM COME, 
Label2.EFont.Italic = BooleanOpt ion. True; 


تكون نتيجة تنفيذ هذا النص البرمجي على الشكل : 
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8 Internet Explorer #0: | O61 - OpenwWawê | ا× افا‎ 


File Info Edit settings Location | 
http://192.168.0.195mitbooksamp > ]|Go| E E E ۹ E E E 


٤ Ela [http:##Aocalhast/mitbooksamples/chapter | 
Centred Title 


Tae wae set f coge 


UTE ENE | 


عنصر التحكم [eطھ]:‏ 
يساعد عنصر التحكم هذا في إظهار نص قصير مخصص للقراءة على خرج شاشة الجهاز المحمول. 


عناصر التحكم الأساسية 
عنصر التحکم )kہLi:‏ 
يساعد هذا العنصر في إنشاء رابط تشعبي على صفحة نموذج الوب المحمول» ويقوم بالربط مع عنصر نموذج آخر ضمن نفس 
الصفحة أومع مصدر ما على الانترنت يُحدد بعنوان 01 له. 


يبين النص البرمجي التالي صيغة استخدام هذا العنصر وأهم الخصائص والأحداث التي يقدمها والقيم التي يمكن أن تأخذها. 
<mobile:Link‏ 

runat="server" 

1d=" E 

Alignment=" {NotSet | Left| Centre| Right}" 

BackColor="backgroundColor"™ 

BEeaRAE EEE rue | Eal Se 

Font-Bold=" {NotSet|False| True}" 

Font-Iltalic="{NotSet |False | True}" 

Font-Name="fontName" 

Font-Size=" {NotSet | Normal | Small | Large} " 
ForeColor="foregroundColor™ 
StyleReference="StyleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap|NoWrap}" 


NavigateUrl="target" 
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SoftkeyLabel="softkeyLabel" 
Text="Text"> 

TextContent 

</mobile:Link> 


من النص السابق نلاحظ أن هذا العنصر يقدم ثلاث خصائص إضافية عن تلك العامة التي سبق وغطيناها. 

الخاصة التمط الضف 

String NavigateUrl‏ تعين هذه الخاصة عنوان المصدر القياسي المراد الوصول إليه. 
String SoftKeyLabel‏ تساعد في تغيير نص القيمة الافتراضية للزر البرمجي الذي توفره 


بعض المستعرضات من 60 إلى أي قيمة مرغوبة أخرى. 
String Text‏ يمكننا تحديد النص الواجب إظهاره كنص للرابط من خلال هذه 
الخاصة. 


يوضح المثال التالي استخدام عنصر التحكم هذا: 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 
Assembly="System.Web.Mobile" %>‏ 
Page Inherits="System.Web.UI.MobileControls.MobilePage™‏ @%5< 
Language="c#" %>‏ 


SMO Le SEO EUNAE< Seve. TIA EOS 
Mooi le UA RK tEAM CUNE = SERVE 
SoftkeyLabel="->Hello" 
NavigateURL="FForm2"> 
GoTo Hello 
</mobile:Link> 
CMOS ELK LOLI AN EUNaAE —Y SEL EE 
SoftkeyLabel="->Bye" 
NavigateURL="#Form3"> 
GoTo Goodbye 
SUMO ILE 2 LARE > 
Mooi le ADK 1ALIM SL CUNE = SERVE 
StyleReference="subcommand" SoftkeyLabel="MSN" 
NaviGgGateURL="NEtEP:/ mobile. MSsnN. COM> 
MSN Mobile 
</mobile:Link> 
MOBI E SE SEMS 


<mMOBm Ke 2: EOGM TIA EOEMZ. EUNICE < SEMEL 
<BSSUSHel IOI </I> </BY 
</mobile:Form> 


MOBI le EOEM 1d EORMSN EFUNaAE= Seve LS 
<B><I>Goodbye</I></B> 
</mobile :Form> 
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توضح اللقطة التالية خرج هذا المثال على محاكي نوكيا ومحاكي 1٤‏ 


3 Internet Explorer 13:16 ا× ادا‎ 


http: ftestmcjlinkexarnplejflinkexamn =~ Ba 


anToa Halo 


GaTa Goodbye 
MSH Mabila 


Yiew Tools 

عنصر التحکم )مi:‏ 

يساعد هذا العنصر في إنشاء رابط ند تشعبي على صفحة نموذج الوب المحمول»› ويقوم بالربط مع عنصر نموذج آخر ضمن نفس 
اق ر درا ع ارا ت ن a‏ 


عناصر التحكم الأساسية 


عنصر التحکم ×0 ۲×٤8‏ : 


يسمح عنصر التحكم هذا بإدخال سطر وحيد كما يمكن لهذا العنصر أن يحتوي قيمة تلقائية مع تمكين المستخدم من تعديل هذه القيمة 
أو استبدالها. 


:] ۵×8 0× فيما يلي صيغة استخدام عنصر تحكم‎ 
<mobile: TextBox 
WIAA IE 1 SEE EEL 
1d= " a 
Alignment=" {NotSet | Left | Centre| Right }" 
BreakAfter==" {True|False}" 
StyleReference="StyleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap|NoWrap}" 


MaxLength="maxlength" 
Numeric=" {True|False}" 
Password=" {True|False}" 
OnTextChanged="textChangedEventHandler"™ 
Size="textBoxLength" 
Text="Text" 
TENE SEE 
WmlFormat="formatMask "> 
TextContent 
</mobile:TextBox> 


نلاحظ أننا قمنا باستبعاد الواصفات المتعلقة بالخط ولونه والخلفية لأنه سيتم إهمالها عند تحويل هذا العنصر. أما بالنسبة للخصائص 
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الأخرى المختلفة عن تلك العامة فهي: 


الخاصة أوالحدث النمط الوصف 

Integer MaxLengh‏ تقوم بتعيين أوإعادة الطول الأقصى المسموح لإدخال النص. 

تعتبر هذه القيمة غير محدودة في حال تعيين هذه الخاصة إلى القيمة 
0. 

TruelFalse Numeric‏ تحدد فيما إذا كان مسموح إدخال القيم الرقمية فقط. 


TruelFalse Password‏ تقوم بتعيين أوإعادة القيمة المنطقية التي تحدد كون الإدخال سيتم 


تشفيره وتحويله إلى إشارات * أوإشارات أخرى. 

Integer Size‏ يحدد طول سلسلة المحارف الذي سيتم تحويل هذا العنصر إليها 

String Text‏ تعبر عن النص ضمن عنصر التحكم» ويمكن تحديد هذا النص 
بطريقتين إما بوضع النص بين فتح وإغلاق تأشيرة عنصر التحكم هذا 
أوبإعطاء قيمة لهذه الخاصة. 

Title‏ تمل هذه القيمة فن لكر ن السك رضات: 

الحدث يقة | تحدد اسم طريقة معالج الحدث. يظهر هذا الحدث عند تعديل محتوى 
TextChanged‏ عنصر التحكم ×1۴×80 وإرسال القيمة المعدلة إلى المخدم. 
wmilFormat‏ تمكن ا۷۷ من تقييد عملية الإدخال بقناع معين. فعلى سبيل المثال 
يحدد القناع NNN‏ إدخال أربع محارف رقمية. 


:TextBox يوضح المثال التالي عمل عنصر تحکم مربع النلص‎ 
<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls"™ 
Assembly="System.Web.Mobile" %> 
<%5@ Page Inherits="MSPress.MobWeb. TBEx.MyWebForm™ 
AutoEventWireup="False" 


Language="c#" CodeBehind="TextBoxExample.aspx.cs" %> 


MOONE SEOEM EUNAE SEE VE EN OOM EN ElE > LCONEIEM EFASSWOEG L> 
MoO NEE Mabe Nl EUR aE < Se ver 1 4A aN > 
Enter new password</mobile:Label> 
<mobile:Label runat="server" id="Label2" Visible="False"/> 
<mobile: TextBox runat="server" id="TextBox1" 
EBASSWO EGS NEUES 
mobile: Tex EBDO; 
OD e SLabeElL EUNaAE= Serve EA IACI 
CORTITT pPasSSuord 
mobile:Label> 
<mobile: TextBox runat="server" id="TextBox2" 
BA SSWOR GS E Ue 
<mobile:Label runat="server" id="Label4"/> 
<mobile:Command runat="server" id="cmdButton">OK</mobile :Command> 
mob le E SEM 


Universal Knowledge Solutions s.a.1 
88 


أما النص البرمجي المرتبط والمحتوى في الملف يء.×مءه.ع1امإهx×٤×‏ 1×80 فهوكما يلي: 


using System; 
USING SYSTEM. WED. UT .MobileConEroOlS; 


namespace MSPress.MobWeb. TBEx 


١ 
public class MyWebForm : System.Web.UI.MobileControls.MobilePage 


{ 


ج 


MoD LECORE EONS, Label 
Mobi LECORE FO lS. Lae I 
‘Mobi lEeECOREEOL SS. Label 
MoD LECORE EONS. HABE I 
MODI LECORE FO LS. HESE BOX UEXEBSX U, 
Mobi lECOREEOLS COmMmMeaRNGd EMOABUE EON, 
MODS LECOREEO NS. OEM EO MN, 

MoD LECORE EONS. KESE EOXS UEXEBONZ, 


protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 


@ @ 
1 


f i 
1 


@ 


@ 
HH 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


} 


piivate vToOId IniitializeComponent (J 


{ 

this. TextBox2.TextChanged += 
new System.EventHandler (this.Verify_OnTextChanged) ; 
EIMLS o CMOBUE EON. CITE = 


new System.EventHandler (this.cmdButton_Click); 


protected void Verify_OnTextChanged (Object sender, EventArgs e) 
{ 
iF (UEeXEBOXL. lex 1> NESEB OX2 UeExXE) 
{ 
Label2.Visible = true; 
Label2.StyleReference = "error"; 
Label2.Text = "No match - please reenter"; 


protected void cmdButton_Click (Object sender, EventArgs e) 
{ 
E (UE EEO „UE — EEO 2 UE) 
{ 
Label1.Visibl = false; 
Label2.Visibl false; 
Label3.Visible = false; 
TextBox1.Visible = false; 
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TextBox2.Visible = false; 
abel TEx - LEO IEMEdM . MANES 


يقوم هذا النص البرمجي بتمكين المستخدم من إدخال كلمة سر وتأكيد صحة الكلمة بإدخالها مرة أخرى باستخدام عنصر تحكم 


التطابق بين الكلمات المدخلة وإظهار رسالة خطاً في حال عدم التطابق أوإظهار رسالة تأكيد عند التطابق. 


EÊ Smart Phone لك‎ 3 Ë Smart Phone 


ar Help Emulator Help Emulator Help 


Confirm Password abc Ts 0 1 ۳ Confirm Password Ty 


Enter new password Enter new password conlirmed- Thanks 
FEREH No match - please reenter 


Confirm password 
e 


عنصر التحکم ×0 ۲٥×٤8‏ : 


يسمح عنصر التحكم هذا بإدخال سطر وحيد كما يمكن لهذا العنصر أن يحتوي قيمة تلقائية مع تمكين المستخدم من تعديل هذه القيمة أو 
استبدالها. 


عناصر التحكم الأساسية 


عنصر التحکم x۷ 1ew‏ آ: 
يسمح عنصر التحكم هذا بإظهار نص طويل لايمكن إظهاره باستخدام عنصر التحكم 1عطج]. 
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تمکین هذه العملية من عنصر النموذج الذي يحوي عنصر التحكم .TextView‏ 


:۲e×)۷ eW يوضح النص التالي صيغة استخدام عنصر تحكم‎ 
<mobile:TextView 
runat="server" 
1d= " 1 " 
Alignment=" {NotSet | Left | Centre| Right}" 
Bale KCl OTS = DAE E IHOURGAE O U OE 
BEE ARATE Ee =< {UE UeE | Eal Se FL 
Font-Bold=" {NotSet|False| True}" 
EONE TlEalIE="INOoOESEE | Bal se | IE Ue} 
HORE Name "1 OR EName 
Font-Size=" {NotSet | Normal | Small | Large} " 


کڪ 


ForeColor="foregroundColor™ 
StyleReference="StyleReference"™ 
Visible=" {True|False}" 


Wrapping=" {NotSet |Wrap |NoWrap}" 


IEE A ESE 
TextContent 
</mobile:TlextView> 


في حالة عنصر التحكم هذا أيضأً نلاحظ وجود خاصة واحدة إضافية عمًا قمنا بتغطيته في الخصائص العامة وهي الخاصة 1٥×‏ حيث 
تحدد هذه الخاصة النص الذي سيظهر ضمن هذا العنصر . 

كما هوالحال في معظم عناصر التحكم التي توفر هذه الخاصةء يمكن ضبط هذه الخاضة أيضاً عن طريق حصر النص بين تأشيرتي 
الفتح والإغلاق لعنصر التحكم هذا. 


يوضح المثال التالي كيفية استخدام هذا العنصر عملياً: 


Page language="c#" 
Inherits="System.Web.UI.MobileControls.MobilePage"™ $%> 
Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


<mobile:Form runat="server" id="Form1" Paginate="True"> 
<mobile:Label id="Label1" runat="server" StyleReference="title" 

Alignment="Center"> 

TextView In Use 

</mobile:Label> 

<mobile:TextView id="TextViewl" runat="server"> 

The TextView control is used for larger blocks of text. 

E. 

<bBE > 
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THIS CONEEON SUSEOEES AMEE Nal CGadinali Om SO EAE ME VOU SEE 
EME OECD AECES/ OS. CONEEON OE CINE CORON: CONEEON EO 
<DEETUe</b>, Ehis cConLIOl WIlI Gace ILS OULU a8 
appropriate for the client browser.<br /> 
OE [3 
It also supports a set of markup elements so that <b>bold</b>, 
SBI BOGE AMO, Ea la CS1 COS, OC CM AEOAlNE </1 Ee SUPPOE EEA 
The line breaks in this text are actually &lt;br/&gt; tags. 
You can also embed &lt;a&sgt; hyperlinks to other resources: 
Be > 
El MEC = ME EOE £ /DOOLLS MOD . COMIC EOE 7 MOSL LE MSN. COME /AE 
</mobile:TextView> 
</mobile:Form> 


Internet Explorer 


http: testrncftextyiewexamplej tex ¥ e ََ 


The Textview control i5 used for larger 
blocks of text, \WAVE 


This control supports internal 

pagination, so that if youı set the 

Paginate control of the Form control 

to true, then this control will page its E ES E a 
output a5 appropriate for the client | af markup eleunentz, 30 


browser, that bold, 
elements, so that bold, tacit aft, [Frewioua ] 
or ar are supported, The line breaks 

in this text are actually <br> tags. 

Toll can also embed <a> hyperlinks to 


It also supports a set of markup 


Yiew Tools 4# A E E> 


عنصر التحکم :T x۷ 1ew‏ 
یسمح عنصر التحكم هذا باظهار نص طویل لایمکن إظهاره باستخدام عنصر التحكم .Label‏ 


تمکین هذه العملية من عنصر النموذج الذي يحوي عنصر التحكم .TextView‏ 


عناصر تحكم الأغراض الخاصة 


تتضمن عناصر تحكم ۸8۲.٤1‏ المحمولة ثلاثة عناصر تحكم ذات أغراض خاصة تشترك في إغناء تطبيقات الوب المحمولة.هذه 
العناصر هي .AdRotator «PhoneCal! «Clendar‏ 
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:Calendar pك>ت عنص‎ 

کو ا ار ن ا ع ا ار و ا ت مرل هه قر رة دا و ا ا 

يوفر عنصر التحكم هذا عدة وضعيات تحدد ما هوالمجال من التاريخ الذي يمكن للمستخدم الاختيار منه مثلا يوم» أوأسبوع» أوشهر. 
يظهر هذا العنصر غالبا بشكل كامل على التجهيزات التي تدعم ا11۷ وبشكل بنية هرمية من الروابط في حالة التجهيزات المحمولة 
التي تدعم .WML‏ 

فيما يلي لقطة توضح شكل هذا العنصر ضمن مستعرضين مختلفين : 


Zoom Tools Help 


۴ 
1 ۳ ternet Explorer A 3:36 9 


http:ffmitchfmitbooksamplesfchapt ¥ 


__ Appointments | Appointments 


Select an option: house a month: Choose a date: ا‎ 
DrO12002 lan ڭ‎ 1 3 


e a date : Mon Tue ed Thu Fri Sat Sun 
| 3 4 5 
N 
Aa E 
a a 
E چ ا‎ 
£ E 


view Tools @ ¥ f Ê 


يبين النص البرمجي التالي صيغة استخدام هذا العنصر وأهم الخصائص والأحداث التي يوفرها: 


<mobile:Calendar 

runat="server" 

1d=" e 

BEE ARA ter Mr Ue Ea SE 
Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small |Large}" 
Font-Bold=" {NotSet|False| True}" 
Font-ltalic=" {NotSet | False | True} " 
ForeColor="foregroundColor"™ 

BACK COILSE  "DIACRISEOURIEO LOE 
Alignment=" {NotSet | Left | Center| Right}" 
StyleReference="styleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap|NoWrap}" 


CalendarEntryText="prompt string" 
FirstDayOfWeek=" {Default | Sunday |Monday | Tuesday | Wednesday | 
IMU SCA [EEALCAAY | SAEUE CEY | Sunde 3 
OnSelectionChanged="selectionChangedHandler" 
SelectedDate="selectedDate" 
SelectionMode=" {None | Day | DayWeek | DayWeekMonth} " 
ShowDayHeader=" {True|False}" 
VisibleDate="visibleDateMonth" 
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نوضح هنا أيضاً الخصائص الإضافية التي لم نقم بتغطيتها أثناء كلامنا عن خصائص عناصر التحكم العامة: 


الخاصة 


CalendarEntry- 
Text 


FirstDayOfWeek 


SelectedDate 


SelectedDates 


SelectionMode 


showDayHeader 


VisibleDate 


WebClendar 


الحدث 
SelectionChanged‏ 


النمط 


String 
System.Web.UI. 
WebControls.FirstDay 


OfWeek enumeration 
(FirstDayOfWeek.Friday) 


DateTime 


Selected DateCo1lecti0¬ غر ض‎ 


System.Web.UI. WebControls. 


CalendarSelectionMode 
NonelDaylDayWeek 
IDayWeekMonth 


True | False 


Date TimeObject 


System.Web.UI. WebControls. 


Calendar 


اسم طريقة معالج الحدث 


يوضح المثال التالي استخدام عنصر التحكم هذا: 


le.aspx.cs" 
leMobileWebForm" 


9 
o> 


Moba le CSE E OS 


runat="server"> 
runat="server" 


الوصف 
تقوم بتعيين أو إعادة النص المستخدم في CHTML, WML‏ 
كرابط للدخول إلى عنصر تحكم Calendar‏ 


تحدد اليوم الأول في الاسبوع الذي ستبداً عنده قائمة الأيام. 


تعين أوتعيد التاريخ الذي تم اختياره بواسطة عنصر التحكم. 
تكون القيمة الافتراضية هي تاريخ اليوم الحالي. 

تقوم بإعادة التواريخ المختارة كغرض 
SelectedDateCollection‏ 

يحدد وحدات التاريخ التي يستطيع المستخدم اختيارها. إذا تم 
تحديد هذه القيمة ب "٥١1٥‏ لن يكون هناك إمكانية للاختيار. 


قيمة منطقية تحدد إظهار أوإلغاء إضافة اسم اليوم إلى التاريخ 
المختار. 

يقوم بالتحكم بالشهر الذي سيتم إظهاره للمستخدم وذلك بتحديد أي 
يوم ضمن هذا الشهر. 

MobileContro1s.Cale ndar ضرغll يغلف‎ 
System. Web. UI. WebControls. ضرغll‎ ja ميل‎ 
Calendar 

والذي يمكن الوصول إليه من خلال هذه الخاصة. 

يحدد اسم طريقة معالج الحدث التي سيتم استدعاؤها عندما يقوم 
المستخدم بتغيير التاريخ المختار ضمن عنصر التحكم. 


<%5@ Register TagPrefix="mobil 
Namespace="System.Web. UI 
Assembly="System.Web.Mobi le" 


چ 


9 
o> 


<%5@ Page language="c#" Codebehind="CalendarExamp l 
Inherits="MSPress.MobWeb.CalEx.CalendarExamp l 


<mMOON le EOE A> LEOEMU 
<mobile:Calendar id="Calendar1"™ 
SelectedDate="2001-07-21" 
SelectionMode="DayWeek" 
Alignment="Center" 


OnSelectionChanged="Calendar1l_SelectionChanged"> 
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</mobile:Calendar> 


<mobile:Label id="Label1" runat="server" Alignment="Center"/> 
</mobile:Form> 


أما بالنسبة للانص البرمجي للملف ءء.×مءه.1eمصةa۲۴×x‏ لدم اه٣‏ فهو كالتالي: 
using System;‏ 
using System.Web.UI.MobileControls;‏ 


namespace MSPress.MobWeb.CalEx 
{ 
public class CalendarExampleMobi leWebForm 
System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web.UI.MobileControls.Calendar Calendarl; 
protected System.Web.UI.MobileControls.Form Forml; 
protected System.Web.UI.MobileControls.Label Label1l; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


} 


private void InitializeComponent () 
{ 
this.Calendar1.SelectionChanged += 


new System.EventHandler (this. 
Calendar1_SelectionChanged) ; 


} 


protected void Calendar1l_SelectionChanged ( 
object sender, 
System.EventArgs e) 


Label1.Text=Calendar1l.SelectedDate.ToShortDateString(); 


نلاحظ في المثال استخدام عنصر التحكم لماه وقد تم إعطاء القيمة الأولية له 21/7/2001 ثم تم تحديد إمكانية الاختيار. 


عند اختيار أي تاريخ آخر غير 21/7/2001 سيتم إطلاق الحدث e4ع,2ط٣«مناءمامS‏ وبالتالي تشغيل الطريقة 
Changed‏ endar1_Selectionاca‏ التي تقوم بتعيين قيمة عنصر التحكم 1.0011 إلى التاريخ الجديد. 
تكون نتيجة تتفيذ هذا النص البرمجي من الشكل: 
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Ê OYWGI1 - Openwaye *| f OYGI1 - Openwaye E Il xl f O0¥G1 - Openwaye 2 ES) 


Fil Info Edt Settings Location Help Fila Info Edit Settings Location Help File Info Edt Settings Location Help 


E) [hite: #*#localhostmitbooksamples#chapter 3 30 [http:#Aocalhost/mitbooksamples/chapter 3 E] iie: ##localhostmibooksamples#chapter 3 


ا 
el‏ 


9 OPENWAVE PENWAVE 


Select an option: / Type a date: | ۴ [Calendar] 
GOT#01/ 2002 {DDHHYYTY} 1 0302/200 
Type a date EReen:| : 

zhoose a date 
Chooze a week 


عناصر تحكم الأغراض الخاصة 


عنصر التحکم 211 :Ph0o ne٣‏ 
يستخدم عنصر التحكم ٣211‏ ,١٠ط‏ الطلب المباشر للاتصال الهاتفي في حال كان الهاتف المحمول يدعم هذا الخيار. أما في حال عدم 
دعم هذه الخاصة يظهر عنصر التحكم هذا وصلة يمكن للمستخدم استخدامها لتفعيل الاتصال أولإظهار رسالة تنبيه المستخدم إلى 

ضرورة الموافقة على تأسيس هذا الاتصال. 


500 500 GG 


NE NLA NE NLA NE NEN 


Card #1 — Service opkions— 
123 A5 F830 Bookmarks | 
Service inbox 1 1 أ‎ 
[ize number _ | 1 
bo to address چ‎ z34 B90 


elect Back DrFktions Clear 
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يبين النص البرمجي التالي صيغة استخدام هذا العنصر وأهم الخصائص والأحداث التي يوفرها: 
<mobile:PhoneCall‏ 
runat="server"‏ 
OWN GOW‏ 
BreakAfter=" {True|False}"‏ 
Font-Name="fontName"‏ 
Font-Size=" {NotSet |Normal | Small |Large}"‏ 
Font-Bold=" {NotSet|False| True}"‏ 
EORE 1lEalI1C=INOESEE  Eal se | lEUe }‏ 
HORE COI OE = i OEE GEOURACES LOE‏ 
BEC KCOLOE > WIIAC KOE OU MOCOLOE‏ 
Alignment=" {NotSet | Left | Center| Right }"‏ 
StyleReference="styleReference"™‏ 
Text="text"‏ 
Visible=" {True|False}"‏ 
Wrapping=" {NotSet |Wrap|NoWrap}"‏ 


AlternateFormat="alternateText" 
AlternateURL="targetURL" 
PhoneNumber="phoneNumber"™ 
SoftkeyLabel="text" 
Text="text"> 

REE ME XE 

</mobile:PhoneCall> 


نوضح هنا أيضاً الخصائص الإضافية التي لم نقم بتغطيتها أثناء تكلمنا عن خصائص عناصر التحكم العامة: 
الخاصة النمط الوصف 


يحدد تنسيق الرسالة التي يجب إظهارها على الجهاز الذي لا 
يستطيع تأسيس الاتصالات الصوتية. 

يمكن أن تتضمن سلسلة المحارف المدخلة أحد القيمتين 
AlternateFormat‏ التاليتين [0] وإ1]. 

يتم استبدال خاصة ٠٠×1‏ بالقيمة [0] والخاصة 
.PhoneNumber‏ 

القيمة الافتراضية لهذه الخاصة هي ”[0[)1]“ 

يعبر عن محدد 081 النسبي أوالمطلق للصفحة التي 
سيجري تحميلها عند عدم تمكن الجهاز من تأسيس الاتصال 
الهاتفي أوعند عدم رغبة المستخدم بالاتصال. 

يمثل الرقم المراد الاتصال به ممثلاً بالتتسيق 
PhoneNumber‏ رمز البلد|الرمز القطري|الرقم القصير. 

يمكن أن تتم عملية التنسيق تلك باستخدام الرموز التالية .() 


AlternateURL 
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- إضافة إلى الفراغ. 

الشاشة. يظهر في هذا الزر القيمة الافتراضية 60 ويمكننا 
تغيير هذه القيمة بتحديد 1ءط2رع))؟ه؟ إلى القيمة 
الطاربة: 

يحدد الرسالة التي سيتم إظهارها للرابط الخاص بتأسيس 
الاتصال. 


SoftkeyLabel 


String 


يوضح المثال التالي استخدام عنصر التحكم هذا: 
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القسم التاسع والعاشر: 


الموضوع الأول:عناصر تحكم نماذج الوب المحمولة 


الكلمات المفتاحية: 


عنصر تحکم»› محمول» لغة تأشيرء تأشيرة» واصفة» خاصة» حدث 


ملخض: 
سنتعرف في هذه الجلسة على عناصر تحكم نماذج الوب المحمولة. ستغطي هذه الجلسة العناصر الحاويةء والأساسيةء وتلك المستخدمة 


للأغراض الخاصة. 


أهداف تعليمية: 
يتعرف الطالب في هذا الفصل على: 
ه٠‏ عناصر تحكم نماذج الوب الحاوية 
ه٠‏ عناصر تحكم نماذج الوب الأساسية 
٠‏ عناصر تحكم نماذج الوب ذات الأغراض الخاصة. 
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عناصر تحكکم الصلاحية 


تعتبر عملية التحقق من صلاحية مدخلات الودج جرا مهم من آي تطبيق: إذ تجري عملية التحقق من الصلاحية لعدة أغراض 
أهمها : 

٠‏ التحقق من اكتمال النموذج. 

٠‏ التحقق من التزام تنسيق معين للبيانات» كحالة البريد الالكتروني مثلا. 

ه٠‏ التحقق من احتواء حقلين على نفس القيمة. كحالة التحقق منحقل كلمة السر ومن حقل تأكيدها. 


تقليدياًء يتطلب أداء مثل هذه المهام نصوص برمجية من جهة المخدم. وهي غالباً ما تحتاج إلى استخدام التعابير النظامية المعقدة. 


توفز ۸8۴.٤٣‏ طريفة جديدة لعملية التحقق من صلاحية النماذج باستخدام عناصر تحكم من جهة المخدم تدعي عتاصر تحكم 
الصلاحية. تسمح هذه العناصر بإجراء عمليات تحقق معقدة بمجرد إدراج التأشيرة الخاصة بعنصر التحكم ضمن صفحة الوب. 


يوضح الشكل التالي البنية الهرمية لصفوف عناصر تحكم الصلاحية: 


System. Web.UIl.MobileControls 
namespace 


نلاحظ من الشكل السابق وجود 5 عناصر تحكم خاصة بالتحقق من الصلاحية هي: 
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عنصر تحكم التعابير النظامية 
عنصر تحكم صلاحية المجال 
عنصر تحكم الصلاحية الُخصص 
عنصر تحكم المقارنة. 


الخاصات العامة لعناصر تحكم الصلاحية 


ترث جمیع عناصر تحکم الصلاحية عدا العنصر «ValidationSummary‏ 
«System.Web. UI.MobileControls.Base Validator‏ llخlصIsValidã.‏ 


تأخذ هذه الخاصة القيمة مu٣‏ إذا كانت شروط التحقق صحيحة» والقيمة ءء[ه۴ إذا فشلت عملية التحقق من الصلاحية. 


يقدم الصف ععWe5.11.۴4.دnعtءرS‏ (وهوالصف الأب للصف ععi1۴aاهM)‏ الخاصة i4اه۷؟1‏ التى تتشكل من عملية AND‏ 
م ي 
منطقية بين جميع خصائص 19۷2114 لعناصر الصلاحية الموجودة في الصفحة. 


ي م 7 E‏ 
الصفحة. 


للوصول إلى مرجع عن المثل عع5.01.۴aءm.۷ءعtءرS‏ من الصف ءعع۴aءMobi1‏ نستخدم llخlصة .MobilePage.Page‏ 


مثال: 
يعرض المثال التالي معالج حدث مرتبط بضغط الزر 1ل«2ة٣١٥K‏ والذي يتحقق من قيمة الخاصة 2114 1!8۷ للصفحة قبل الانتقال 


:۴٥۲٣2 إلى النموذج‎ 
protected void Command1_Click (object sender, System.EventArgs e) 


1 
// Move onto second Form only if input on first page has 
// passed validation by all the validation controls on the 


1f (Page. TSVolld) 
{ 


NEE IVEHOEM — EOEMZ; 


} 


في حالة وجود خطاً يظهر النموذج من جديد مع رسالة من أجل كل عنصر تحكم صلاحية تسبب في هذا الخطأ. 


تظهر عناصر تحكم الصلاحية الرسائل بشكلين أساسيين: 
الأول في نفس المكان الذي قمت فيه بإدراج عنصر تحكم الصلاحية على النموذج 
٠‏ والتاني ضمن مساحة العرض الخاصة بعنصر تحكم .ValidationSu ary‏ 
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يجري تحديد رسالة الخطاً التي ستظهر بالشكل الأول باستخدام الخاصة .1٠×1‏ أما في حالة استخدام عنصر التحكم 
Summary‏ idationاa.‏ فيجري استخدام الخاصة ععهءءع 8۲٠۲۷‏ وفي هذه الحالة يجب إسناد القيمة ٥"٥‏ إلى قيمة الخاصة 
yهام2is‏ لعنصر تحكم الصلاحية نفسه» لضمان عدم ظهور رسالة الخطاً مرتين» مرة عن طريق عنصر التحكم 
dation Summary‏ ومرة عن طريق عنصر تحكم الصلاحية نفسه. 


يبين الجدول التالي أهم الخصائص المشتركة لعناصر التحقق من الصلاحية: 
الخاصة النمط الورصف 
مُعرف 10 لعنصر التحكم المراد 


String ControlTo Validate 
التحقق منه.‎ 


System.Web.UI. WebControls 
.ValidatorDisplay 


NonelStaticlDynamic Display 


تحدد إظهار رسالة الخطأ أولا. 
String ErrorMessage‏ إظهارها ضمن خر ج عنصر التد> 
ValidationSummary‏ 

True | False IsValid‏ تحدد فيما إذا كانت البيانات صالحة. 
تمثل الرسالة التي سيجري 
إظهارها. 

في حال لم يجر تعيين قيمة لهذه 
الخاصةء يجري إظهار قيمة 
llخاصة ErrorMessage‏ رضنا 
عنها. 

لا يتم إدارج هذه القيمة ضمن خرج 
ValidationSummary‏ . لهذ 
الغرض تم إيجاد القيمة 


.ErrorMessage 


عناصر تحكکم الصلاحية 
عنصر تحكم iنفحJa RequiredField Validator‏ 


يعتبر هذا العنصر أبسط أشكال عناصر تحكم الصلاحية وأكثرها استخداما. يقوم هذا العنصر ببساطة بالتحقق فيما إذا قام المستخدم 
بإعطاء قيمة لعنصر إدخال معين أم لا. 
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تكون الصيغة التي تساعد في استخدام هذا العنصر في صفحة نموذج الوب المحمول هي التالية: 


<mobile: RequiredFieldValidator 
runat="server" 
MEOW OW 
BreakAfter=" {True|False}" 
Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small | Large} " 
Font-Bold=" {NotSet|False| True}" 
Font-Italic="{NotSet |False | True}" 

HORE CO lO =— E OEE GEOURAES OE 

Bae KE OO = Dale RGEOURGIE OS O 

Alignment=" {NotSet | Left | Center| Right }" 
StyleReference="styleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap |NoWrap}" 


CONTTOITOVaITIIAT ET IOUOTTATGETLCONETOILT 

Display=" (None[ STatiCcC|Dyneamic}" 
ErrorMessage="ErrorTextForSummary™ 
IMilCialValûe="initialValueInTheControl" 
Text="ErrorText"™> 

innerText 


</mobile: RequiredFieldValidator> 


جميع خصائص هذا العنصر موروثة عن الخصائص العامة لعناصر التحقق من الصلاحية والتي يوفرها الصف ١140ا‏ ۷ء8 . 


استخدام عنصر التحكم :RequierdField Validator‏ 
يشر ح المثال التالي استخدام عنصر التحكم a0۲‏ ل 1ا 14۷ء۴ dاعRequi‏ حيث يطلب من المستخدم إدخال اسمه ضمن النموذج وعند 


إرسال النموذج يجري التحقق من كون الحقل قد تم إعطاؤه قيمة: 
Page Inherits="MSPress.MobWeb. ReqEx. RequiredExamp le"‏ 
CodeBehind="RequiredExample.aspx.cs"‏ 
Language="C#"%>‏ 
Register TagPrefix="mobi le"‏ 
Namespace="System.Web.UI.MobileControls"™‏ 
Assembly="System.Web.Mobile" $>‏ 


MOSM LE EOEM OA HOM EURA EL Se VEEL 
<mobile:Label id="Label1" runat="server"> 
Your name: 
</mobile:Label> 
<mobile:TextBox id="userName" runat="server"/> 
<mobile: RequiredFieldValidator id="RequiredFieldValidator1" 
runat="server" 
Display = Dynamic 
ErrorMessage="Your name is required! " 
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ControlToValidate="userName"/> 
MOO E  COMNAREA ME COMMaNEOI ONCILTEK = COMMA CEE 
E IEE = SOME YS 
SUOMI 
</mobile:Command> 
MOB le E OEMS 


MOONE SEOEM MA LEOMZ BUMA =1 Sea VEL 
<mobile:Label id="Label2" runat="server"> 
Thout validated OL. 
</mobile:Label> 
</mobile:Form> 


أما النص البرمجي العامل في الخلفية فهربالاسم cs‏ .لRequiredExamp1e.as5‏ 


using System; 


namespace MSPress.MobWeb. ReqEx 
{ 
public class RequiredExample : 
System.Web.UI.MobileControls.MobilePage 
1 
protected System.Web.UI.MobileControls.Label Label1l; 
protected System.Web.UI.MobileControls. TextBox userName; 
protected System.Web.UI.MobileControls.RequiredFieldValidator 
RequiredFieldValidatorl; 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.Form Forml; 
protected System.Web.UI.MobileControls.Label Label2; 
protected System.Web.UI.MobileControls.Form Form2; 
override protected void OnInit (EventArgs e) 


{ 


InitializeComponent () ; 
base.OnInit (e); 


1 


private vVoOlId InictializeCcomponent () 


{ 


ELS . CEMIL CIA — 
new System.EventHandler (this. Command1_Click); 


protected void Command1_ Click (object sender, System.EventArgs 


{ 
1f (Fagêe.TSsValid) 


{ 


Nel VeROEIN — BOEMZ, 
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تكون نتيجة التنفيذ لهذا المثال من الشكل 
LCE Remote Display : CE Remote Display :‏ 
Fil Zoom Tools Help Fil Zoom Tools Help‏ 


http: fmitchfmitbooksamplesfchapt = ھ‎ http: fmitchfmitbooksamplesfchapt = م‎ 


Your name: Tour Name: 


Your name is required! 


Yiew Tools 4% @ ا ا ا‎ E Yiew Tools 4 ¥ ا ا‎ E 


عناصر تحكم الصلاحية 
عنصر تحكم lئnمقlرiنة CompareValidator‏ 


يُستخدم هذا العنصر في عملية مقارنة لقيمتين من قيم عنصر تحكم إدخال. 


تكون الصيغة التي تساعد في استخدام هذا العنصر في صفحة نموذج الوب المحمول هي التالية: 
<mobile:CompareValidator‏ 
runat="server"‏ 
1d="id"‏ 
BreakAfter=" {True|False}"‏ 
Font-Name="fontName"‏ 
Font-Size=" {NotSet | Normal | Small | Large} "‏ 
Font-Bold=" {NotSet|False| True}"‏ 
Font-ltalic=" {NotSet |False | True} "‏ 
ForeColor="foregroundColor"™‏ 
BackKCOlOr="backKIrOURNdCOLOE‏ 
Alignment=" {NotSet | Left| Center| Right }"‏ 
StyleReference="styleReference"™‏ 
Visible=" {True|False}"‏ 
Wrapping=" {NotSet |Wrap|NoWrap}"‏ 


ControlToCompare="IdOfControl"™ 
CORLEOLITOVALIIAT E TOUOTTAETELCONTEOLT 
Display=" {None | Static | Dynamic} " 
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ErrorMessage="ErrorTextForSummary"™ 

Operator=" {DataTypeCheck | Equal | GreaterThan | 
GreaterThanEqual | LessThan 

LessThanEqual |NotEqual }" 

Text="errorText" 
Type=" {Currency| DateTime | Double| Integer|String}" 
ValueToCompare="Value"> 

innerText 

</mobile:CompareValidator> 


يرث عنصر التحكم هذا مجموعة الخصائص العامة التي يوفرها الصف 0۲اه لناة۷ءءه8B‏ التي مررنا على ذكرها مسبقاً. إضافة إلى 
هذه الخصائص» يوفر هذا العنصر الخصائص الإضافية التالية: 


الخاصة النمط لضت 
تمل هذه الخاضة عامل 


المقارنة بين القيمتين 


System. Web. UI Operator 


.WebControls 


ValueTo-Compare 


.ValidationCompareOperator 
DataTypeChecklEquallGreater Than 
IGreaterThanEqual 
lLessThanlLessThanEquallNotEqual 


System. Web. UI 

.WebControls 

.Validatio-DataT'ype 
StringlIntegerlDoublelDatelCurrency 
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المّدخلتين حيث تتوضع 
القيمة الممثلة ل 
ControlToV alidate‏ 
في الجزء الأيسر لهذا 
العامل والقيمة الممثلة ل 
Control ToCompare‏ 
في الجزء الأيمن له 
واستعادة 


يقوم بتحدید 
نمط البيانات 
الراك مقار نتهما: 
المدخلة قسرياً إلى نمط 
البيانات المحدد قبل 
إجراء عملية المقارنة. 


أُما إذا فشلت عملية 


التحويل تلك فإن عملية 
يجري إسناد قيمة إلى 
هذه الخاصة إذا أردنا 
مقارنة الخاصة ۲٥×)‏ 
لعنصر تحكم 

ControlToV alidate 


مع قيمة ثابتة معينة 
الخاصة 1٥×‏ لعنصر 
تحکم آخر. 
Control ToCompare‏ يمتل المُعرف 150 

لعنصر التحكم المراد 
لمقارنة معه حيث تجري 
مقارنة قيمتي الخاصتين 
× ا لكل من عنصري 
التحكم ذوي المحددين 
ID‏ 


Control ToCompare 
ControlToValidate s 


استخدام عنص llتحكp :Compare Validator‏ 
يشرح المتال التالي استخدام عنصر التحكم Compare Validator‏ حیث يطلب من المستخدم إدخال كلمة السر ضمن عنصر التحكم 
ssw1هم‏ و إعادة تأكیدها بإدخالها ضمن عنصر تحكم آخر 5۷0۲۵2ءهم. عند إرسال النموذج يجري التحقق من تطابق القيمتين . 


<%5@ Page Inherits="MSPress.MobWeb.CmpEx.CompareExample" 
CodeBehind="CompareExample.aspx.cs" 
Language="C#"%> 
<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


<mobile:EForm id="EForml" runat="server"> 
<mobile:Label runat="server"> 

Your Password 

</mobile:Label> 

MOO NE CIES EBOS IGS PASSWOSG IL EURO E= SEF MEE l1 DASSMOEI= EEUE > 

<mobile:Label runat="server"> 

Retype password 

mobile:Label> 

obile:TextBox id="password2" runat="server" password="true"/> 

obile:CompareValidator id="CompareValidator1" 
Type="String"™ 
Operator="Equal 
runat="server" 
ErrorMessage="Passwords do not match!" 
ControlToCompare="password1"™ 
COontrolToValidate="basSsword2"/> 

<mobile:Command id="Commandi1 " 
ORCI EK= COMMA CTE K U EUR ESL SERVE 
SOM 
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< /mMObi le : Command > 
< /mMOb1 Le $ EOEM> 


<mMolb le SEOEM TA EOEMZL UNAE= SER VERS 
<mobile:Label runat="server"> 
Passwords match! 
</mobile:Label> 
</mobile:Form> 


أما النص البرمجي العامل في الخلفية فهوبالاسم CompareExample.aspx.cs‏ 


using System; 


namespace MSPress.MobWeb. CmpEx 
{ 
public class CompareExample 
System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web. .MobileControls.Label Label1l; 
protected System.Web. .MobileControls.TextBox passwordl; 
protected System.Web. .MobileControls.Label Label2; 
protected System.Web. .MobileControls.TextBox password2; 
protected System.Web. .MobileControls.CompareValidator 
CompareValidatorl; 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.Form Forml; 
protected System.Web.UI. 1leControls.Label Label3; 
protected System.Web.UI. i LECORNE EONS. ESEM HOEMZ; 


override protected void Lt (EventArgs e) 
1 

InitializeComponent () ; 

base.OnInit (e); 


private void InitializeComponent () 


1 


ERALS . Commendl1 . CICK 4= 
new System.EventHandler (this. Command1_Click); 


} 


protected void Command1_ Click (object sender, System.EventArgs 


1 
1f (BPage.IsValid) 


{ 


NEE IVEROEM — BOEMZ;, 
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تكون نتيجة التنفيذ لهذا المثال على الشكل 


E 


عناصر تحكم الصلاحية 
عنصر تحكم تحديد nllجJl RangeValidator‏ 


يستخدم عنصر التحكم هذا في التحقق من وقوع قيمة ضمن مجال محدد. 
تكون الصيغة التي تساعد في استخدام هذا العنصر في صفحة نموذج الوب المحمول هي التالية: 


<mobile:RangeValidator 
runat="server" 
1d=" E 
BreakAfter=" {True|False}" 
Font-Name="fontName" 
Font-Size=" {NotSet | Normal | Small | Large}" 
Font-Bold=" {NotSet|False| True}" 
Font-ltalic=" {NotSet | False | True} " 
EOEECOLSE  "TOEFEIEOURICO LOE 
BackColor="backgroundColor"™ 
Alignment=" {NotSet | Left | Center| Right}" 
StyleReference="styleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap | NoWrap}" 


CONEEOITOValidalte="TOOFTIEOSEECONETEOL 
Display=" {None | Static | Dynamic} " 
ErrorMessage="ErrorTextForSummary"™ 
MinimumValue="minValue" 
MaximumValue="maxValue" 
Text="errorText" 
Type=" {Currency| DateTime | Double | Integer | String}"> 
innerText 
</mobile:RangeValidator> 
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يرث هذا العنصر مجموعة الخصائص العامة التي يوفرها الصف ١0هل‏ اة ۷ءعءه8 التي مررنا على ذكرها ميقا إضافة إلى هذه 
الخصائص يوفر هذا العنصر الخصائص الإضافية التالية: 


الخاضة 1 الوصف 


القيمة الدنيا الواجب 
توفرها للعنصر ذي 
المُعرف 

ControlTo Validate 
بنجاح.‎ 


MinimumV alue 


القيمة الدنيا الواجب 
توفرها للعنصر ذي 
المُعرف 
ControlToValidate‏ 
Maximum Value‏ بنجاح. حيث تمتل 
الخاصتان 

Minimum Value 
Maximum Value y 
قيماً إجبارية يجب‎ 
إدخالها.‎ 

يقوم بتحديد واستعادة 
نمط البيانات الخاصة 
بالقيمة المراد مقارنتها. 
يتم عندها تحويل القيمة 
System.Web.UI. WebControls. ValidationDataType‏ ال اة قن ي الىت 
البيانات المحدد قبل 
إجراء عملية المقارنة. 
أما في حال فشل عملية 
التحويل تلك فإن عملية 


StringlInte gerlDoublelDatelCurrency 


استخدام عنص تكم :RangeValidator‏ 

يشرح المثال التالي استخدام عنصر التحكم إ0اةل1اة ۷ ءع,ه۸ الذي يطلب من المستخدم إدخال تاريخ ميلاده ضمن عنصر تحكم 

»1٥×80×‏ حيث تكون القيمة العليا المسمو ح بإدخالها هى تاريخ ميلاد يمتد إلى 21 عاماً من تاريخه أما القيمة الدنیا فهی التاري: 
e‏ هي داریح 1 من دارډ ا هي الناريح 
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0/. 
نلاحظ هنا أنه تم تنفيذ الجزء الخاص بإعطاء القيمة البدائية للخاصة عuاةu”۷صن×ة۸‏ ضمن النص البرمجي 
.RangeExample.aspx.cs‏ فيما يلي النص البرمجي xضRangeExample.asp‏ 


Page Inherits="MSPress.MobWeb.RgeEx.RangeExamp le" 
CodeBehind="RangeExample.aspx.cs" 

Language="C#" AutoEventWireup="False" %> 

Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls"™ 


Assembly="System.Web.Mobile" %> 


MOONEE EOEM IAL EOEMIN EUNICE SEE VEEL > 
mobi le Label EUNRat= I Ser Ver, 
Dae OE OEE 
</mobile:Label> 
<mobile:TextBox id="dob" runat="server"></mobile: TextBox> 
<mobile:RangeValidator id="RangeValidatorl" runat="server" 
Ma a1 mum al ue O17 ONTO O 
COME E O1 TOME Û 1E Ee = EOI 
ErrorMessage="Sorry, you are not 21."> 
</mobile:RangeValidator> 
MOA e * COMMANGS MOL CONMARELE EUAN SCE VCE COE SUOMI 
</mobile: Command> 
</mobile:Form> 


MOG le SE OEM AI HOCMZL BUNE Se Ve 
moO le: Label OE Label ZE EUNAE< SEVERE lS 
Welcome, you are over 21. 
</mobile:Label> 
</mobile:Form> 


أما النص البرمجي العامل في الخلفية فهوبالاسم x.csضRangeExample.as‏ 


using System; 


namespace MSPress.MobWeb. RgeEx 
{ 
public class RangeExample : System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web.UI.MobileControls.RangeValidator 
RangeValidatorl; 
protected System.Web. 1leControls.Label Label1l; 
protected System.Web.UI.MobileControls. TextBox dob; 
protected System.Web. .MobileControls.Command Command1l ; 
0 
8 
3 


protected System.Web. ‘MOSH LE COREEOLS EOEM EOEMU; 
protected System.Web. .MobileControls.Label Label2; 
protected System.Web. MoM LECOREE OLS. EOEM EOEMZ; 


override protected void OnInit (EventArgs e) 


1 
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InitializeComponent () ; 
Base. On INI (e); 


} 


private void InitializeComponent () 
{ 
this.Load += new System.EventHandler (this.Page_Load) ; 


EMAL S . COMME. CITE — 
new System.EventHandler (this. Command1_Click); 


} 


protected void Command1_Click (object sender, System.EventArgs 


1 
if (Bage.ISsValid) 


{ 


NEE IVEROEM — BHOEMZ; 


} 


private void Page_Load(object sender, System.EventArgs e) 

{ 

DateTime now = DateTime.Now; 

DateTime dt21yearsago = 

new DateTime (now.Year - 21, now.Month, now.Day, 0, 0, 


RangeValidator1.MaximumValue = 

JEEZ IvVear Sa 0O. TOSROE EDAEE SE EAR (DF 

RangeValidator1. Type = 
System.Web.UI.WebControls.ValidationDataType. Date; 


تكون نتيجة تنفيذ هذا المتال من الشكل: 
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اخاوا ا 
Fil Zoom Ionls Help Eil Zoom Tonls Help‏ 


Tr 
1 


2 # 4:16 5 ر‎ Internet Explorer 


http: fmitchfmnitbooksarmplesfchapt ¥ http: fmitchfmnitbooksamplesfchapt ¥ ê 


Date of birth: Date of birth: 


U302/ 1988 0302/1388 


Softy, YOU afte hot Z1, 


shift] z [x [c[¥[bÎnÎm].,[. [¥#| 
ctlaûl’ [1]  ][+[?|[+|a+l __ 
Yiew Tools 4 4#] ۹ Ê E Yiew Tools 4% ¥] | ا‎ | 


عناصر تحكم الصلاحية 
عنص تكم RegularExpressionV alidator‏ 


يسمح هذا العنصر باختبار قيمة حقل والتأكد بأنها توافق صيغة معينة. فعلى سبيل المثالء يمكننا استخدام هذا العنصر للتحقق من إدخال 
قيمة البريد الالكتروني» والرمز البريدي» والرقم الوطني. 


يعد هذا العنصر أكثر تعقيدأ من عناصر الصلاحية الأخرى التي قمنا بمناقشتها حتى الآن ولكن عمله يظل أقل تعقيدا من محاولة العمل 
مباشرة مع التعابير النظامية دون استخدام عنصر التحكم هذا. 


تكون الصيغة التي تساعد في استخدام عنصر تحكم Expression ۷ a11 a0۲‏ arاRegu‏ في صفحة نموذج الوب المحمول هي التالية: 


<mobile:RegularExpresssionValidator 

ta WAE 1 SEE EEL 

NOW GOW 

BreakAfter=" {True|False}" 
Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small |Large}" 
Font-Bold=" {NotSet|False| True}" 

EOnNE lEal1c"INOotSeE | Eal se | Ir ue } 
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EHOEECO LOE  TOEFEIEOURIEO LOE 
BackColor="backgroundColor"™ 
Alignment=" {NotSet | Left | Center| Right }" 
StyleReference="styleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap|NoWrap}" 


CONTEOITOVALIQGaA TC" TOOETaTOGTCONTEEOLT 

Display=" {None | Static | Dynamic} " 

ErrorMessage="ErrorTextForSummary"™ 

Text="ErrorText"™> 

ValidationExpression="regexp" > 
innerText 


</mobile:RegularExpressionValidator> 


يرث عنصر التحكم هذا مجموعة لخصائص العامة التي يوفرها الصف ١0اه‏ ل11اة ۷ء8 التي مررنا على ذكرها مسبقاً. 


إضافة إلى هذه الخصائص يوفر هذا العنصر الخاصة الإضافية التالية: 
الخاصة النمط لوضف 


String ValidationExpression‏ تمثل هذه الخاصة التعبير النظامي الذي يجب تحقيقه. 


استخدام عنصر lلتحكم :RegularExpression Validator‏ 
نظراً لكون عملية كتابة التعبيرات النظامية مربكة بعض الشيء» توفر بيئة 0نلدا؟ اهنءز۷ معالج يظهر لدى إضافة عنصر 
Regular Expression Validator‏ ويوفر مجموعة من أكثر التعبيرات النظامية استخداماً. يظهر هذا المعالج شاشة من الشكل: 


Regular Expression Editor 


Standard Expressions: 


P,R.Z, Phone Number 

|P.R.Z, Postal Code 

P,R,Z, Social Security Nurnber (ID Number} 
L.5. Phone Murnber 

(U.S. Social Security Number 


e | | 


يشر ح المثال التالي استخدام عنصر llتحكpم RegularExpression Validator‏ 
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RegularExample.aspضل فيما يلي النص البرمجي‎ 
Page Inherits="MSPress.MobWeb. RegEx. RegularExample”" 
CodeBehind="RegularExample.aspx.cs" Language="c#"$%> 
Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" $%> 


Smo le Eom iA OEM EUR E = Se VER 
<mobile:Label runat="server"> 
ANE Code 
</mobile:Label> 
<mOBile :TextBox 1d="zip" runat="server" /> 
MOO NE COMMA iA CommanoO ll FUMAE LSE Ver 
OME LEK = Comme meli CITE HES 
SUMS E 
</mobile:Command> 
<mobile:RegularExpressionValidator 
1d="ReGgularExpressionValidatorl" 
runat="server" 
ErrorMessage="Invalid ZIP Code" 
COME EON OMAN LEA E= Uz OY Ul ICAI LOM OEE SSO E OOF (E EOLA OMS 
</mobile:Form> 


<mMOom le EOEM IA HOEMZL EURNAESL SE VERS 
<mobile:Label runat="server"> 
Valid ZIP Code 
</mobile:Label> 
</mobile:Form> 


أما النص البرمجي العامل في الخلفية فهوبالاسم x.csضRangeExample.as‏ 


using System; 


namespace MSPress.MobWeb. RegEx 
{ 
public class RegularExample 
System.Web.UI.MobileControls.MobilePage 
1 
protected System.Web.UI.MobileControls.Label Label1l; 
protected System.Web.UI.MobileControls. TextBox Zip; 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected 
System.Web.UI.MobileControls.RegularExpressionValidator 
RegUlLarExpresslonValidatorl; 
protected System.Web.UI.MobileControls.Form Forml; 
protected System.Web.UI.MobileControls.Label Label2; 
protected System.Web.UI.MobileControls.Form Form2; 
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override protected void OnInit (EventArgs 
ا‎ 

InitializeComponent () ; 

base.OnInit (e); 


} 


private void InitializeComponent () 


{ 


EMA GS, COMIN CELE = 
new System.EventHandler (this. Command1_Click); 


} 


protected void Command1_ Click (object sender, System.EventArgs 


{ 
1f (Page.IsValid) 


{ 


Net ive EOEM < EOEMZ, 


يقوم هذا البرنامج من التأكد من كون قيمة عنصر التحكم 1٠×80×‏ المحدد بقيمة م10=71p‏ يحقق 
."\d{5}C\d{4})?"‏ 


عناصر تحكم الصلاحية 


CustomV alidator عنصر تكم‎ 


يختلف هذا العنصر عن بقية عناصر التحكم لأنه لايوفر وظيفة التحقق من الصلاحية بصورة مباشرة. ويساعد هذا العنصر في إنشاء 
طريقة التحقق من الصلاحية. 


تكون الصيغة التي تساعد في استخدام عنصر تحكم ١0اةل‏ ناج۷" هاوا٣‏ في صفحة نموذج الوب المحمول هي التالية: 


MOON E: CUSE ONA AGA EOE 

runat="server" 

1d="id" 

Br eaRAT ter = (| lruUe  Eal Se) 
Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small |Large}" 
Font-Bold=" {NotSet|False| True}" 

EOE lEalICE= I NOESEE  Eal Se | UE Ue 
ForeColor="foregroundCo lL 
BackColor="backgroundCo 1l 
Alignment=" {NotSet | Left| Center| Right}" 


2 


StyleReference="styleReference"™ 
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IESE WIS 1E OE ECE 
Visible=" {True |False}" 
Wrapping=" {NotSet |Wrap|NoWrap}" 


CORTEOITOVSLIQaT C=" TOOfFTarGETCoONTEEOLT 
Display=" {None|Static| Dynamic}" 
ErrorMessage="ErrorTextForSummary"™ 
OnServerValidate="EventHandler"™ 
Text="ErrorText"> 

innerText 


</mobile:CustomValidator> 


يرث عنصر التحكم هذا مجموعة الخصائص العامة التي يوفرها الصف ١0ا‏ :1ة ۷ء8 التي مررنا على ذكرها مسبقا. 


إضافة إلى هذه الخصائص يوفر هذا العنصر حدث إضافي هوالتالي: 

الحدث النمط الوضف 

يجري إطلاق هذا الحدث عند التحقق من الصفحة 
على المخدم. يستقبل معالج الحدث المعامل 

Server lidateEvent Ars‏ لذا یجب علی معالج 
الحدث إسناد عuإ‏ إلى قيمة 11d‏ ۷ء] الخاصة 
بالغرض Server Validate ٤۷e 114g‏ إذا كانت 


ServerValidate 


يمكن أن يكون شكل معالج هذا الحدث كما يلي: 


vOid ServerValidate (Object source, ServerValidateEventArgs args ) 


{ 


args.IsValid=false; 
// Code to validate the user's input 


IE (valida E1 OMISSUCCE SSE UL) 
args. IsValid=true; 


استخدام عنصر إلتحكم :CustomV alidator‏ 


يشر ح المثال التالي استخدام عنصر llتھĞڌp CustomValidator‏ 


فيما يلي النص البرمجي لضExample.as Custom‏ 
Page Inherits="MSPress.MobWeb.CusEx.CustomExample"‏ @%5< 
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CodeBehind="CustomExample.aspx.cs" 
Language="C#"$%> 
Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls"™ 
Assembly="System.Web.Mobile" $%> 


moon le :EOEM IAG LOMIL CUNE SERVERS 
MOA Ne SLKabDel EURO SERVE LY 
Enter an integer 
</mobile:Label> 
<mobile:TextBox id="number" runat="server"/> 
MOA NE CUS E OMVANIGAEOE aA CUS EOMVaAN TSA EOE 
runat="server" 
ErrorMessage="Not a factor of four" 
CORREO TOMA NGA E E = N UMOEE 
OnServerValidate="ServerValidate"/> 
moi le SCommanma ia CoMmMaAMGO IL 
ONCLT E VEO CNC Y EUNICE SH SOK UO 
SOME 
</mobile:Command> 
</mobile:Form> 


<mMolC le: EOE AA EOEMZ EURNAES< SERVERS 
<mobile:Label runat="server"> 
A Tract OE OE FOUE. 
</mobile:Label> 
</mobile:Form> 


أما النص البرمجي العامل في الخلفية فهوبالاسم ئx.cضRangeExample.as‏ 


using System; 
using System.Web.UI. WEbDCoONTEOLS; 


namespace MSPress.MobWeb.CusEx 
{ 
public Class CuUSstomExamgple 
System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web.UI.MobileControls.Form Form2; 
protected System.Web.UI.MobileControls.Label Label1l; 
protected System.Web.UI.MobileControls.CustomValidator 
CustomValidatorl; 
protected System.Web.UI.MobileControls.Command Commandi1l ; 
protected System.Web.UI.MobileControls.Form Forml; 
protected System.Web.UI. lleControls.Label Label2; 
protected System.Web.UI. lleControls. TextBox number; 
override protected void 1t (EventArgs e) 


1 


InitializeComponent () ; 
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base.OnInit (e); 


} 


private void InitializeComponent () 


{ 


EMS ¢, COMMON CLE = 

new System.EventHandler (this.Command1_Click); 
this.CustomValidatorl1l.ServerValidate += 

new ServerValidateEventHandler (this.ServerValidate ); 


} 


protected void Command1_ Click (object sender, System.EventArgs 


1 
1f (Page. IsValid) 


{ 


NEE VEROEM = BOEMZ; 
} 
} 


protected void ServerValidate ( 
object source, 
ServerValidateEventArgs args) 


args.IsValid=false; 
EW 


nt32.Parse (number. Text); 


9 
6 


args. IsValid=true; 
1 
} 
catch (FormatException e) 
{ 
// Exception may be caused by 
// non-integer input on HTML clients 


يقوم هذا البرنامج من التأكد من كون الرقم المدخل في عنصر تحكم ×180×ع1 المسمى إ٤طاإناد‏ هومن مضاعفات العدد 4. 


تم كما نرى إضافة عنصر التحكم 1١٥2t0ل1اة‏ ۷ Custom"‏ وربط حدث التحقق من الصلاحية على المخدم بالطريقة ServerV alidate‏ 
والتي تم تفصيل عملها ضمن الملف البرمجي Custom Example.aspx.cs‏ 


عناصر تحكم الصلاحية 
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عنص تكم ValidationSummary‏ 


يقوم هذا العنصر بإعادة ملخص عن الخرج من جميع عناصر التحقق من الصلاحية المستخدمة ضمن نماذج الوب التي تحتويها 
الشفحة 


يكون لخر ج عنصر التحكم هذا فائدة كبيرة في التطبيقات المحمولة كونه يسمح بتشكيل رسالة خطأً ضمن كتلة نصية واحدة مما يسمح 
بتحسين استخدام التطبيق على التجهيزات ذات مواصفات العرض المحدودة. 


تكون الصيغة التي يستخدمها عنصر التحكم هذا هي التالية: 


<mobile:ValidationSummary 

runat="server" 

1d="1id" 

BreakAfter=" {True|False}" 
Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small | Large}" 
Font-Bold="{NotSet|False| True}" 
Font-ltalic=" {NotSet |False | True} " 
ForeColor="foregroundColor™ 
BackColor="backgroundColor"™ 
Alignment=" {NotSet | Left | Center| Right }" 
StyleReference="styleReference"™ 
Visible=" {True|False}" 
Wrapping=" {NotSet |Wrap|NoWrap}" 


BacklLabel="BacklLabel" 

E OENTOVA LAA EE EOE DE 

HeaderText="HeaderText"> 
</mobile:ValidationSummary> 


نلاحظ هنا وجود ثلاث خصائص إضافية غير مألوفة هي : 


الخاصة النمط الوضف 

String BackLabel‏ إذا إعطاء قيمة لهذه الخاصة 
فسيجري استخدامها كنص للرابط 
الذي يعيد المستخدم إلى نموذج 
الإدخال لإعادة إدخال النص من 
جدید. 

FormToValidate‏ ر و دچ انی کا اکن 
من صلاحیته. 

HeaderText‏ تمثل العنوان الذي يسبق قائمة 
الأخطاء. 
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يجري إظهار قيمة هذه الخاصة في 
أعلى الصفحة في حالة 
المستعرضات التي تستخدم 
11M‏ وقبل كل رسالة خطأاً في 
مستعرضات WML‏ 


إذا تم وضع عنصر التحكم ضمن نفس النموذج الذي يحتوي عناصر تحكم التحقق من الصلاحية سيتم بعد إجراء عملية التحقق على 
المخدم إعادة عنصر التحكم ValidationSum mary‏ مظهرا الخاصة ءع4ءء٥ 8٥١۲۷‏ لجميع عناصر التحقق من الصلاحية التي 
تبين أن قيمة الخاصة 4ناة1]۷ لها هي عواج۴. 


أُما إذا تم وضع عنصر التحكم 21¥y‏ 15٥1هل‏ 1اه ۷ ضمن نموذج مغاير لذلك الحاوي على عناصر تحكم التحقق من الصلاحية 
الأخرى فعندها يجب على معالج حدث الضغط على عنصر تحكم ك«ةص ٥٥٣‏ الذي قام بإرسال الصفحة اختبار قيمة لiاة۷ء1‏ 


للصفحةء فإذا اتضح أن قيمة هذه الخاصة (15۷111) هي ٥ء[ھ۴‏ فیجب تعیین قيمة الخاصة ۴٥۲۳‏ ٥1۷ء۸‏ بحیٿ تشیر إلى النموذج 


الحاوي على عنصر التحكم Sum‏ 10n)هل‏ 1اه .في هذه الحالة يجب إعطاء قيمة للخاصة 1ء 12ء84 بحيث تكون ذات دلالة 
للمستخدم مثلا Re)‏ . 


عند إعطاء قيمة للخاصة 1ءط14)ء 84 يقوم العنصر Validation Su‏ تلقايا بالربط مع النموذج الذي يتم التحقق من 


:Validation Su 1¬ary استخدام عنصر التحكم‎ 


يشرح المثال التالي استخدام عنصر llتحكp ValidationSummary‏ 


Summary Example.asضل فيما بلي النص البرمجي‎ 
<%5@ Page Inherits="MSPress.MobWeb. SumEx. SummaryExample" 
CodeBehind="SummaryExample.aspx.cs" 
Language="C#"%> 
<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" $%> 


<mMOoOON le: EOEM 14A HOEMIL EUNAE< See LS 
MOON NEE LaloolL EL aloel LY Une HEEL VENE NS 
Your name: 
</mobile:Label> 
<mobile:TextBox id="userName" runat="server"/> 
<mobile:Label id="Label2" runat="server" > 
Password 
mobile:Label> 
obile:TextBox id="password" runat="server" Password="True"/> 
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<mobile: RequiredFieldValidator id="RequiredFieldValidator1" 
runat="server" 
ControlToValidate="userName" 
Display="None" 
ErrorMessage="Your name is required!"/> 
<mobile:RequiredFieldValidator id="RequiredFieldValidator2" 
runat="server" 
ControlToValidate="password™ 
Display="None" 
ErrorMessage="A password is required!"/> 
<mobile:Command id="Command1" runat="server" 
OCLC SWCOMMENCNL CILERKYS 
E IOI E 
</mobile:Command> 
</mobile:Form> 


<mobile:Form id="Form2" runat="server"> 
<mobile:ValidationSummary id="ValidationSummary 1" 
runat="server" 
HeaderText="Missing Values:" 
FormToValidate="EForm1l" 
BackLabel="Retry"/> 
</mobile:Form> 


MOG le SEO AG HORM EUNAESL Se VERS 
<mobile:Label runat="server"> 
Error free submission. 
</mobile:Label> 
VIMO EE BOM 


أُما النص البرمجي العامل في الخلفية lg‏ اسم SummaryExample.aspx.cs‏ 


using System; 


namespace MSPress.MobWeb. SuUMEx 
{ 
public class SummaryExample 
System.Web.UI.MobileControls.MobilePage 
{ 


protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.Form Form2; 
protected System.Web.UI.MobileControls.Form Form3; 


override protected void OnInit (EventArgs e) 
InitializeComponent () ; 
base.OnInit (e); 
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private void InitializeComponent () 


1 


ENS o CONIA  CILLE — 
new System.EventHandler (this.Command1_ Click); 


} 


protected void Command1_Click (object sender, System.EventArgs 


{ 
1f (Page. TsVali1d) 
1 
ActiveForm HOF; 
} 
else 
{ 
ActiveForm 


1 


أُما نتيجة تشغيل هذا النص البرمجي فتكون على الشكل: 


E simulator 2 nlx E simulator 


ا 


Your HarmB: Missing 'Yalues: 
[ | Your name iS 
required! 

A password is 


Password 


مثال شامل حول استخدام عناصر تحكم الصلاحية 


فمل ت هذا الال على تفم ترذ ج خان بطب كال رمات تالكر وتي وتاك ران ارت ےه كحي ميلح لر ع 
لمؤسسة خيرية ما . يجب على النص البرمجي التحقق أولا من إدخال صيغة البريد الالكتروني بالشكل الصحيح» والتطابق بين القيمتين 
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المدخلتين لهذا البريد. كذلك يجب أن يتم التحقق من كون جميع الحقول لها قيمة قبل عملية الإدخال. 
يكون المبلغ الخاص بالتبرع يجب ألا يكون أقل من 5 أكثر من 1000. 
شكل الواجهة المتوقع الحصول عليها في هذا المثال: 


E-mail address] 
Re-trpe e-mail] 
Donation (min. e5] 


Donate! | 


» E-mail address requred 
» Tou rmust re-type e-mail 
» Tou rmust enter an atnouiit 


<%5@ Page Inherits="MSPress.MobWeb.ValEx.ValidationExample" 
CodeBehind="ValidationExample.aspx.cs" Language="c#" $%> 

<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


<mobile:Form id="Eorml" runat="server"> 
<mobile:Label runat="server" BreakAfter="false"> 
E-mail address: 
</mobile:Label> 
<mObDi11le:TextBox 1d="emaill" runat="server" /> 
<mobile:RequiredFieldValidator id="RequiredFieldValidator1" 
runat="server" 
ErrorMessage="E-mail address required" 
ControlToValidate="email1" 
Display="None"/> 
<mobile :RegularExpresSsionValidator i1d="RegularExpressionValidatorl" 
runat="server" 
ControlToValidate="emai l1" 
ValidationExpression="\w+ ( [-+.] \w+) *@\w+ ([-.]\w+) *\.\w+ ( [= 
0 
Not a valid e-mail address 
</mobile:RegularExpressionValidator> 


<mobile:Label id="Label2" runat="server" BreakAfter="false"> 

Re-type e-mail 

</mobile:Label> 

<mobile:TextBox id="email2" runat="server" /> 

<mobile:RequiredFieldValidator id="RequiredFieldValidator2"™ 
runat="server" 
ErrorMessage="You must re-type e-mail" 
COE 1 OL TOMA EEE = HEMEN 12 
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Display="None"/> 


<moDIlE:COMpGpareValidaltor 13="COompareVvalidatorl” 
runat="server" 
ErrorMessage="E-mail addresses do not match. 
ControlToValidate="emai1l2"™ 
ControlToCompare="email1" 


Display="None"/> 


le:Label id="Label3" runat="server" BreakAfter="false"> 
DOR aE KON (min. E5) 


<mob i 


</mobile:Label> 


IEE TEX EEOS MOA AORAETORL EUR LSE VEE PASSWOEG- NEUE 
le:RequiredFieldValidator id="RequiredFieldValidator3" 


<mobi 
<mob i 


runat="server" 
ErrorMessage="You must enter an amount" 
CONEEOITOVaALIGda Te Iona IoNT 
Display="None"/> 
<!-—- The RangeValidator Control requires that a maximum value is 


This value could represent the payment ceiling accepted by the 
online payment service provider =-> 
<mobile:RangeValidator id="RangeValidator1" 
runat="server" 
ControlToValidate="donation™ 
Type="Currency" 
MinimumValue="5" 
MaximumValue="1000"> 
Minimum donation 1S $5 
</mobile:RangeValidator> 


E COMMER A= Command l1l. Una E= Seve l> 
Donate! 


<mob i 


</mobile:Command> 


e:ValidationSummary id="ValidationSummary1" 


<mob i I 


runat="server" 
E OFEmMIOVaA NAGA e EOE 
</mobile:Form> 


le EOEM 1S EOEMZL CUNE SEEMEFLS 
le:Label id="Label4" runat="server"> 
Thank Yol for donaling. 


<mobi Il 


</mobile:Label> 
</mobi le :EOrM> 


أما النص البرمجي العامل في الخلفية فهو : 


<mobi J] 


using System; 


namespace MSPress.MobWeb.ValEx 


public class ValidationExample : 
System.Web.UI.MobileControls.MobilePage 
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{ 


{ 


protected System.Web.UI.MobileControls.Label Label1l; 
protected System.Web.UI.MobileControls.TextBox email1l; 
protected System.Web.UI.MobileControls.RequiredFieldValidator 
RequiredFieldValidatorl; 
protected 
System.Web.UI.MobileControls.RegularExpressionValidator 
RegularExpresslonVal idatorl; 
protected System.Web.UI.MobileControls.Label Label2; 
protected System.Web.UI.MobileControls.TextBox email2; 
protected System.Web.UI.MobileControls.RequiredFieldValidator 
RequiredFieldValidator2; 
protected System.Web.UI.MobileControls.CompareValidator 
CompareValidatorl; 
protected System.Web.UI.MobileControls.Label Label3; 
protected System.Web.UI.MobileControls.TextBox donation; 
protected System.Web.UI.MobileControls.RequiredFieldValidator 
RequiredFieldValidator3; 
protected System.Web.UI.MobileControls.RangeValidator 
RangeValidatorl; 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.ValidationSummary 
Valida Ions UMmMar YI, 
protected System.Web.UI.MobileControls.Form Forml; 
protected System.Web.UI.MobileControls.Label Label4; 
protected System.Web.UI.MobileControls.Form Form2; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


} 


private void InitializeComponent () 


1 


EMAL o, COMMON CELE #— 
new System.EventHandler (this.Command1_ Click); 


protected void Command1_ Click (object sender, System.EventArgs 


1 
11 (PaJe,TSVIIlN) 


{ 


NEE IVEHOEM — EOEMZ; 
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القسم التاسع والعاشر: 


الموضوع الثاني: عناصر تحكم نماذج الوب الخاصة بالقوائم 


الكلمات المفتاحية: 


عنصر تحکم»› محمول» لغة تأشيرء تأشيرة» واصفةء خاصة» حدث 


ملخض: 
سنتعرف في هذه الجلسة على عناصر تحكم نماذج الوب الخاصة بالقوائم» حيث ستغطي هذه الجلسة عناصر تحكم القائمة 


.SelectionList , List , ObjectList 


أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على: 
ieصر SelectionList pill‏ 
٠‏ عنصر التحكم ایز 
٠‏ عنصر التحكم tء0bjecti.‏ 
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عناصر تحکم القائمة 


سنغطي في هذا الجزء وظائف تلاثة عناصر تحكم تقدم للمستخدم قائمة من الأغراض: 
عنصر <؟p Selection List‏ 
عنصر ت<Ğ۾p ListControl‏ 
عنصر تحکم .0bject 1s)‏ 


وللوصول لفهم أكبر حول هذه عناصر نبين هرمية الصفوف الخاصة بتلك العناصر: 


System. Web. Ul. MobileControls 
namespace 


فيما يلي قائمة تشمل أهم الفروقات والمزايا التي يقدمها كل عنصر من عناصر التحكم السابقة: 

الميزة ObjectList SelectionList‏ 
يمكن إظهاره بشكل قائمة منسدلة أوقائمة اختيار أوخيارات 
رادیوعلی مستعرضات اH1M‏ 


X N 
۰ يدعم تعدد الخيارات‎ 

يمكن إظهاره على شكل قائمة ثابتة غير تفاعلية 
يمكن إظهاره على شكل قائمة تعداد نقطي أورقمي 
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اع ا 0 ا ماه 
يمكن التصريح عن عناصر الإظهار بصورة ساكنة 
یمکن ربطها بمصدر بیانات 

يمكنها إظهار حقلين أوأكثر من عنصر بيانات 


عناصر تحكم القائمة 
عنص ت<Ğۃم Selection List‏ 


يناسب عنصر تحكم اءا«هذاءم1م؟ القوائم الصغيرة كونه لا يدعم عملية التقطيع إلى صفحات بالنسبة للقوائم الطويلة. ولكن يمكن 
لهذا العنصر إظهار القائمة بشكل قائمة منسدلة أوقائمة عناصر راديوعلى المستعرضات التي تدعم هذه العناصر. 

يعرض عنصر التحكم قائمة مكونة من عمود واحد كما يدم إمكانية ربط قيمة مخفية بكل قيمة ظاهرة. يمكننا تحديد هذه القيمة من خلال 
الواصفة ع٠1ه۷‏ المرتبطة بالعنصر <صع)ن> أوتحديد قيمة الخاصة 14٥۴ع‏ ں 1ة 2۷اه في حالة القائمة المرتبطة بمصدر بيانات. 


تكون صيغة استخدام عنصر التحكم هذا على الشكل: 

<mobile:SelectionList 

runat="server" 

1d="1id" 

Alignment="{NotSet|Left|Center|Right}" 

Ba eK CO lo =— "Bae RGTFOURAECS OE 

BreakAfter=" {True|False}" 

Font-Bold="{NotSet|False| True}" 

EONRE  lEal1 C=" {(NOESeEE | Eal se | TEUe } 

Font-Name="fontName" 

Font-Size=" {NotSet |Normal | Small | Large} " 

ForeColor="foregroundColor™ 
StyleReference="StyleReference"™ 
Wrapping=" {NotSet |Wrap |NoWrap}" 


DataMember="dataMember" 

DataSource="dataSource"™ 

DaltalextEHi elGE- DAA EeE SEEN 

DataValueField="DataValueField"™ 

SelectType=" {DropDown| ListBox| Radio|MultiSelectListBoOx| CheckBox}" 
TIEClIES SETTING 
OnItemDataBind="itemDataBindHandler" 
OnSelectedIndexChanged="selectedIndexChangedHandler"™> 


SS OBEIORMAN SEA LEA lly Cec laEread lis iEeMS >> 
<Item Text="Text" Valüue='"Walue" Selected="{Irue |Ealse}"/> 


< / mobile :SelectionLiStE> 
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الخصائص والأحداث: 


فيما يلي أهم الخصائص والأحداث التي يقدمها عنصر التحكم SelectionContro1‏ 


الخاصة أوالحدث 


DataMember 


DataSource 


DataTextField 


DataValueField 


النمط 


System. Web.UI.MobileControls 
.MobileListItemCollection 


Integer 


نستخدم هذه الخاصة عندما يکون عنصر 


التحكم مرتبطاً بغرض من نوع 

System.Data. DataSet 

أو 

System.Data.DataTableObject 

تحدد هذه الخاصة الغرض اع5ه)2 5 
أوص10اءعا1ه الذي سيتم الربط معه 
عندما يكون عنصر التحكم مرتبطاً بمصدر 
بیانات. 

في حال ربط عنصر التحكم بغرض 
DataSet‏ أوبغرض ٤0118٥101‏ تحدد 
الخاصة 14ع (a) 1 ex×)۴‏ اسم الحقل 
الذي ستظهر محتوياته ضمن القائمة ضمن 
مصدر البيانات. 

في حال ربط عنصر التحكم بغرض 
DataSet‏ أوبغرض ٥0118٥1010‏ تحدد 
الخاصة Data Valu e۴11‏ اسم الحقل 
الذي مسقتخم حكرياته ضس قم انيافات 
کے ول که 
القائمة 

توفر هذه الخاصة الوصول إلى غرض 
MobileListltemCollection‏ 

الذي يحتوي جميع أغراض 


System. Web.UI.MobileControls. 
MobileListltem 


المعبرة عن أغراض القائمة المخزنة. 
عندما یتم إسناد ×0 8ء1 

و MultiSelectListBox‏ إلى الخاصة 
مم Sec‏ يجري استخدام الخاصة 
لتحديد عدد الصفوف المرئية من 
عنصر التحكم وذلك في المستعرضات 
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التي تدم CHTML, HTML‏ 
تقوم بإعادة أوتحديد دليل العنصر المختار. 
أما في حال كان عنصر التحكم في 
وضعية الاختيار المتعدد فيجري إعادة 
دليل العنصر الأول المختار. 

تقوم بإعادة غرضص العنصر المختار 
MobileListltem Selection‏ وهومن النمط e0‏ )])s¡عMob¡1‏ أوتعید 


Integer SelectedIndex 


System.Web.UI. 
MobileControls. ListSelectType 
تحدد هذه الخاصة نمط إظهار القائمة في‎ 


. حال دعم المستعرض للنمط المختار‎ DropDownlListBoxlRadiol 
MultiSelectList-BoxlCheckBox 


SelectType 


العنوان الذي يظهر على مستعرضات 
.WML‏ 

هذا العنوان غير مدعوم في العديد من 
مستعرضات WML‏ 

تحدد اسم طريقة معالج الحدث 


OnltemDataBind(Object Sender , 
ListDataBindEventsArgs e) 


|“ : ۰ 
الحدث Item Data Bind‏ يجري إطلاق هذا الحدث عندما يجري 
تجري عملية إعادة إطلاق هذا الحدث عند 
إضافة عنصر إلى القائمة. 


إذا تم إعداد عنصر التحكم 
stاectionاe‏ للعمل بوضعية الاختيار 
الوحيدء يجري إطلاق هذا الحدث في كل 
مرة تجري فيها عملية إرسال النموذج مع 
تغيير في العنصر المختار. 


الحدث 
SelectedIndexChanged‏ 


استخدام عنص llت<pS :SelectionControl‏ 
لاستخدام هذا العنصر يمكننا تحديد عناصر القائمة باستخدام التأشيرة <٠6ان>‏ ضمن التأشيرة الخاصة بهذا العنصر أو بربط العنصر 


يمكننا تحديد نمط عنصر التحكم هذا من خلال الخاصة ءمرآاء٥1عS‏ حيث تظهر الأنماط المختلفة تبعاً دعم المستعرض للنمط. 
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Internet Explorer 17:48 
[http:fflocalhast/MITBookSarnples/C [| 


GrapÛown w 


Itemz 
Item3 


Radin 
Itema 
Ortema 
MultiSelect Listbox 


lL JharckBox 


[| lıtem2 
Yiew Tools ك4‎ 


مثال1: 
بين المثال التالي استخدام عتصر ااتحكم: 


<%5@ Page Inherits="MSPress.MobWeb.SelListEx.ExampleWebForm™ 

Language="c#" 
CodeBehind=" SingleSelectionListExample.aspx.cs"%> 

<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


<mMOON le SEOEM EUNAE= SEE VEEN MSA MOEN L> 
<mobile:Label runat="server" StyleReference="title" id="Label1"> 
Season 2003 results 
</mobile:Label> 
mobi le LAE Nl EUR < Se VEE 14A ON 2 > کا 6اا صت‎ 
team: </mobile:Label> 
<mobile:SelectionList SelectType="ListBox" 
1EW SELECE LORLLEE LA EUMIEE— SEE EOE HS 
Si Eem Text = Dunes Va lle POSMSl 21l29 BES: 0L 
iE EmM Rext 1 EROeR Ix 1 Valle LDPOSM 2 BIS BES OLS 
<item Text="Eagles" Value="Posn:3 Pl:38 Pts:69"/> 
<itEm Text="iodiac" Vols PoSN:4 PI: PIS COO. 
</mobile:SelectionLISE> 
Molo le RE OMMaARS SURA E SERVE 1 MA- COMMA 
Get Stats! 
</mobile:Command> 
moO le E OSEM> 


MOOI LE SEOEM EUNAE SEE VEEN SA MOM ZAL 
<mobile:Label runat="server" id="Label3">Team Full 
Stals:</mobile:Label> 
<mobile:Label runat="server" id="Label4"/> 
</mobile:Form> 
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يقوم النص البرمجي السابق بإنشاء نموذجين: يحتوي الأول قائمة تستخدم ائ«هناءم1مS‏ تظهر معلومات إضافية عنها ضمن 
الواصفة عuں‏ اه۷ المرتبطة بالتأشيرة <صإع)1>. 


فيما يلي النص العامل في lالlفıة SingleSelectionListExample.aspx.cs‏ 


using System; 
namespace MSPress.MobWeb.SelListEx 
{ 
public class ExampleWebForm 
System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web.UI.MobileControls.Label Label4; 
protected System.Web.UI.MobileControls.SelectionList 
SelectionlListl; 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.Form Form2; 


override protected void OnInit (EventArgs e) 
1 

InitializeComponent () ; 

base.OnInit (e); 


} 


private void InitializeComponent () 


{ 


ERIS. COmMmandal Clie t— 
new System.EventHandler (this.HandleTeamSelection) ; 


} 


private void HandleTeamSelection (Object source, EventArgs args) 
1 
// Display the Stats page 
ELS ACEI VERON = FO MZ f 
String selectedTeamStats = SelectionList1.Selection.Value; 
Label4.Text = SelectionList1.Selection + "; " 
+ selectedTeamStats; 


} 


مثال 2: 
لوحاولنا إعادة هذا المثال لتقديم إمكانية الاختيار المتعدد» يصبح مثالنا على الشكل: 
Page Inherits="MSPress.MobWeb.MultSelListEx.ExampleMobileWebForm™‏ 
Language="c#" CodeBehind="multipleselectionlistexample.aspx.cs"$%>‏ 
Register TagPrefix="mobi le"‏ 
Namespace="System.Web.UI.MobileControls"‏ 
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Assembly="System.Web.Mobile 


MOON le SEOEM EUNAE =1 SEE VEE US MOM L> 
<mobile:Label runat="server" StyleReference="title"> 
Season 2003 results 
</mobile:Label> 
<mobile:Label runat="server">Select 2 or more teams:</mobile:Label> 
<mobile:SelectionList SelectType="MultiSelectListBox" 
1E WEE LECELONLLSE LYS EUNaE=WSEE VEE FS 
<item Text="Dunes" Value="Posn:1 Pl:38 Pts:80"/> 
ECM ext = PROC xX ValUCE- POS 22 N30 EES: OLIV 
<item Text="Eagles" Value="Posn:3 Pl:38 Pts:69"/> 
a Eem ext = Zod ael Val Ue LEOSN I4 ENES EES OSS 
</mobile:SelectionList> 
MOO NE COMMA EUNaAE Sever IIE COMMAS 
Compare Stats! 
</mobile:Command> 
</mobile:Form> 


<mMolb le EOE EUNAES< SERVE. TGA OMS 
<mobile:Label runat="server">Teams Full Stats:</mobile:Label> 
<mobile:TextView runat="server" id="TextViewl"/> 
</mobile:Form> 


أما النص البرمجي العامل في الخلفية فيكون : 


using System; 
uSing SYSTEM. Web. UL. MobileConTrOol1S; 


namespace MSPress.MobWeb.MultSelListEx 
{ 
public class ExampleMobi leWwebForm 
System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web.UI.MobileControls.TextView TextViewl; 
protected System.Web.UI.MobileControls.SelectionList 
ELEC ET1 ONES E LF 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.Form Form2; 
override protected void OnInit (EventArgs e) 


{ 


InitializeComponent () ; 
base.OnInit (e); 


} 


private void InitializeComponent () 


{ 


ERAS. COmmanadal Cele t> 
new System.EventHandler (this.HandleMultiTeamSelection) ; 


} 


protected void HandleMultiTeamSelection (Object source, EventArgs 
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EMLS ACE VOOM = FO MZ f 

// Get the lit 1tems €COLLECELOR e 

MOO LEILA SE IE SMCOLIECE LON COLLEEMS = SEIECE IONLALSE Û, LESS ¢ 
SEAMS SErLDLS OLAV EexX E > CL; 

foreach (MobilelListltem item in colIltems) 


1 


if (item.Selected) 
{ 


strDisplaytext += (item.Text + ": " + item.Value + 


} 
} 
TextViewl.Text = strDisplaytext; 


حيث قمنا باستخدام التركيب 1ءه٠۲٥]‏ للتحقق من العناصر المختارة وإظهارها. 


تظهر نتيجة تنفيذ المثال بعد التعديل كما في الشكل التالي: 
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ر ا اا 


مثال 2: 
يتناول المثال التالي نفس الفكرة السابقة مع عملية ربط لعنصر التحكم ائااممناءم‌آامS‏ مع مصدر بيانات والذي يمثله هنا الغرض 
:Array List ط¦طaill ja array‏ 


<%5@ Page Inherits="MSPress.MobWeb. DBListEx.Examp leWebForm" 
Language="c#" 
CodeBehind="DataboundListExample.aspx.cs" AutoEventWireup="False" 


Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


<mMolO le EOE EUNAE< SERVE TGA OM LS 
<mobile:Label id="Label1" runat="server" StyleReference="title"> 

Season 2003 results 

</mobile:Label> 

<mobile:Label id="Label2" runat="server"> 

Select 2 or more teams: 

</mobile:Label> 

MMOL E SEOLECE TOLLS 1OASUOELECE LOLI SELLY EUMNENE =H SE vez 
DataValueField="Stats" DataTextField="TeamName" 
SelectType="MultiSelectListBox"> 

</mobile :SeleCE1 ORLA SE > 

<mobile:Command id="Command1" runat="server"> 

Compare Stats! 
</mobile:Command> 

</mobile:Form> 


<mMolb le EOE EUNAES SERVE. TG OMS 

moO Ne label IES Hae l SE EFUNAE>  SCEVEE NEA S EU 
Stalts:</mobile:Labelz> 

<mobile:TextView id="TextViewl" runat="server"></mobile:TextView> 
</mobile:Form> 


أما النص البرمجي العامل في الخلفية فهو : 


using System; 
using System.Collections; 
USING SVETEM. WED. UI .MODIlECONTEEOILS; 


namespace MSPress.MobWeb. DBListEx 
{ 
public class ExampleWebForm 
System.Web.UI.MobileControls.MobilePage 
{ 


protected System.Web.UI.MobileControls.TextView TextViewl; 
protected System.Web.UI.MobileControls.SelectionList 
SELECETORIT SE LF 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.Form Form2; 
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override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


} 


pEivate vVoOl1d InicializeCcomponent () 
{ 
this.Load += new System.EventHandler (this.Page_Load) ; 
EMAL ES COMME. CITE — 
new System.EventHandler (this.HandleMultiTeamSelection) ; 


} 
private void Page_Load(Object sender, EventArgs e) 
1 

ISEOSEBaACK) 


ArrayList array = new ArrayLisi(); 
array.Add (new TeamStats ("Dunes", "Posn:1 PlLl:38 


array.Add (new TeamStats ("Phoenix", "Posn:2 Pl:38 


array.Add (new TeamStats ("Eagles", "Posn:3 PlLl:38 


array.Add (new TeamStats("Zodiac", "Posn:4 Pl1:38 


SelectionList1.DataSource = array; 
SelectionList1.DataBind(); 


private void HandleMultiTeamSelection ( 
Object source, EventArgs args) 
1 


ERIS. ACEIVEEOEM = HOFMZ; 


// Cer the LiGtl 1E@MS COLLECELOM e 
MobilelListItemCollection colIlItems = SelectionList1. Items; 
SEEING SETDiSplaylexl = FE, 

foreach (MobileListltem item in colIltems) 


{ 


1f (item.Selected) 
{ 
SErEDISplavltext ¥= (Item. Tlexl FF "; F + Item. Value +t 
Ey, 
} 
} 
TextViewl.Text= strDisplaytext; 


class TeamStats 
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{ 


private String teamName, stats; 


public TeamStats(String teamName, String stats) 
{ 

this.teamName = teamName; 

EMIS GSEAES < SEES 


lic String TeamName { get { return this.teamName; } } 
TiS SEEDO SEAS OCE ( FEEUEN ENIS SEAS, || 


عناصر تحكم القائمة 
عنصر تحکم ئ1 


يشبه هذا العنصر عنصر تحكم ائ" ]ءام الذي قمنا بمناقشته ساق بفرق أن عنصر التحكم 1.15 يدعم عملية تقسيم خر ج القائمة 
إلى عدة صفحات مما يقدم فائدة كبيرة في حالة القوائم الطويلة على الأجهزة المحمولة ذات شاشات الإظهار المحدودة الإمكانيات. 


يمكننا استخدام هذا العنصر أيضاً في حالة الرغبة بعرض قوائم تفاعلية وغير تفاعلية. في حالة القوائم التفاعلية لسنا بحاجة إلى زر 
خاص لعملية إرسال البينات إلى المخدم» إذ يتولى عنصر التحكم هذا عملية إرسال البيانات لدى النقر واختيار أحد العناصر. 


يدعم عنصر التحكم ء11 القوالب مما يجعل عنصر التحكم هذا مناسباً في حالة برمجة الاستجابات المتعددة المرتبطة بنوع الجهاز 
المستخدم. 


تكون الصيغة الخاصة باستخدام عنصر التحكم هذا هي التالية: 

<mobile:List 

runat="server" 

1d="1id" 

Alignment=" {NotSet|Left|Center|Right}" 

BackColor="backgroundColor™ 

Font-Bold="{NotSet|False| True}" 

Eont lEalic=l{NOoESEeE | Ealse | IEUe 

Font-Name="fontName" 

Font-Size=" {NotSet |Normal | Small| Large}" 

ForeColor="foregroundColor™ 
StyleReference="StyleReference"™ 
Wrapping=" {NotSet |Wrap |NoWrap}" 


DataMember="dataMember " 
DataSource="dataSource"™ 
DataTextField="DataTextField"™ 
DataValueField="DataValueField" 
Decoration=" {None | Bulleted | Numbered} " 
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/> 


ItemsAsLinks=" {False | True}" 
TEeMCOUMIE <1 1 ECEM COU E 
OnItemDataBind="onItemDataBindHandler" 
On I EeEmEC omma no ORME eMC oOmMnanEHaAnd lek 
OnLoadItems="loadItemsHandler"> 


a OCEIONaAL SEaEIEeallyY Gecelared liSE items >> 
<Item Text="Text" Value="Value" Selected=" {True|False}" 


< AMO le : LA SZ 


يقدم عنصر التحكم هذا كما نرى مجموعة من الخصائص والأحداث نذكر أهمها: 
String‏ تستخدم هذه الخاصة عند ارتباط عخصر الكتحكم هذا 


DataMember 


DataSource 


DataTextField 


DataValueField 


Decoration 


ItemsAsLinks 


ItemCount 


بمصدر بیانات مثل غرض ع245 

أو م1 t2ه(.‏ حيث تحدد اسم الجدول ضمن 
غرض 4561( الذي يجب ربط عنصر التحكم 
به. 

عند ارتباط هذا العنصر بمصدر بيانات» تحدد هذه 
الخاصة غرض ١‏ ٥i0اءع[1ه‏ أوام؟هtه(‏ يمتثل 
مصدر البيانات. 

عندما يكون عنصر التحكم مرتبطاً بغرض 
DataSet‏ أوectionا1هC‏ تحدد هذه الخاصة اسم 
الل كن مصتن الياتات الذي فبك إظهارة 
ضمن القائمة. 

عندما يكون عنصر التحكم مرتبطاً بغرض 
DataSet‏ أوectionا1هC‏ تحدد هذه الخاصة اسم 
الحقل ضمن مصدر البيانات الذي سيقدم القيم 
المخفية المرتبطة بكل عنصر من عناصر القائمة. 
System.Web. UI‏ تحدد هذه الخاصة على المستعرضات التي تدعم 


.MobileControls.‏ ا 1 ا 
٢1M | ]istDecoration‏ شكل إظهار عناصر القائمة. 


NonelBulletedlINumbered 
تستخدم في حالات خاصة عندما نرید استخدام قيم‎ ۴۵۴ ۴6 

×1 واه لكل عنصر في القائمة بمثابة نص 

ارتباط ومحدد 0۸1[ الخاص به. 

عند تكون قيمة هذه الخاصة ع1۲1 يقوم 

المستعرض بالانتقال مباشرة إلى المصدر المحدد 

ولا يجر توليد أي حدث اختيار 

1۲ م م تعيد هذه الخاصة العدد الكامل لعناصر القائمة. 
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النحدث ItemCommand‏ اسم طريقة معالج الحدث | يحدد معالج الحدث الواجب استدعاؤه عندما يختار 


المستخدم عنصر من القائمة إلا في حال تعيين 
قيمة llخاصة True yJ ItemsAsLinks‏ 
الحدث LoadItems‏ اسم طريقة معالج الحدث | يتم إطلاق هذا الحدث عند محاولة تحميل عناصر 
جديدة إلى القائمة من مصدر البيانات. 

تتم هذه العملية عادة عند تفعيل إمكانية التقسيم إلى 
صفحات حيث تترافق كل عملية تحميل بانطلاق 
لهذا الحدث. 


استخدام عنصر التحكم )ءأ: 
ذكرنا سابقاً أنه يمكن استخدام هذا العنصر بوضعيئين: 
- الوضعية غير التفاعلية: يتم في هذه الوضعية إظهارعناصر القائمة دون القدرة على الاختيار. يمكن هنا تحديد شكل الإظهار 
باستخدام الخاصة .[8٥0۲3)10١‏ ويجب عدم تحديد قيمة لمعالج الحدث ٣۳0۳١2٣١‏ .ع)! في هذه الحالة. 
الوضعية التفاعلية: في حال تم تعيين قيمة لمعالج الحدث أ١هد٣‏ إ0 ٣٣‏ .ع1 يجري تحويل كل عنصر من عناصر القائمة 
لرابط يقوم باستدعاء معالج الحدث عند النقر عليه. 
متال1: 
يوضح المثال التالي استخدام عنصر التحكم هذا: 
Page Inherits="MSPress.MobWeb.ListItmCmd. MyWebForm" Language="c#"‏ @%5< 
CodeBehind="ListItemCommandExample.aspx.cs"%>‏ 
Register TagPrefix="mobi le"‏ @%5< 


Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


MOON LE EOE EUNAE = SEE VE E SOOM LY 
<mobile:Label runat="server" id="Label1l" StyleReference="title"> 
Season 2003 results 
</mobile:Label> 
MOA Ne Label LURNAE > Ser VEE 120 al 21 ا6 اا‎ 
team: </mobile:Label> 
MOSAIC SLA S E EFUDNAE SEO A SEN L> 
Eom ext = DUNES Value LPOSMENl EIS BES: OLS 
iE em Wext PMOL Valle POS 2 EI SC EES OL 
<item Text="Eagles" Value="Posn:3 Pl:38 Pts:69"/> 
<iEem Mex Zod IAS 1e PESNA PILI PESOS 
</mobile:List> 
</mobile:Form> 


MOC LE EOE EUNAE < Seve TITEL 
<mobile:Label runat="server" id="Label StyleReference="title"> 
Team BULL SEAS: 
</mobile:Label> 
<mMoOM le Label EUNAE = Ser Ve 4 1 lz 
</mobile:Form> 
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أما النص البرمجي العامل في الخلفية فهو : 
using System;‏ 
using System.Web.UI.MobileControls;‏ 


namespace MSPress.MobWeb.ListItmCmd 
{ 
public class MyWebForm : System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web.UI.MobileControls.List Listl; 
protected System.Web.UI.MobileControls.Label Label4; 
protected System.Web.UI.MobileControls.Form Form2; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


} 


private void InitializeComponent () 


1 


this.Listl. I[temCommand += new 
ListCommandEventHandler (this.ClickTeamSelection) ; 


private void ClickTeamSelection ( 
Object source, 
ListCommandEventArgs args) 


// Display the Stats page 
EMIS. ACEI VEE OEM = MOE, 
String strSelectedTeamStats = args.ListItem.Value; 
Label4.Text = args.ListItem. Text 
SN ST SELSeElECEECAUEeAMSEAE SF, 


نلاحظ في النص البرمجي أننا قمنا بتحديد العنصر المختار من خلال المعامل عه الذي تم تمريره إلى معالج الحدث 
"eam Selection‏ ickاC‏ حيث يمكن الوصول إلى النص والقيمة باستخدام اlنصيغ args.Listltem. Texts args.ListItem. Value‏ 


تكون نتيجة تشغيل هذا المثال على الشكل التالي: 
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e Internet Explorer 3 10:46 0 


http: fcmhgltp10fmitbooksarmplesjc ¥ چ‎ 


Season AÛO0O3 results 
Select a tearm: 


التقسيم إلى صفحات بصورة آلية أومخصصة: 
بعكس عنصر التحكم اءاا”هناءعام؟ يتحدر عنصر التحكم هذا من الصف اهإ٤«ره٣4ءعه۴‏ أي أنه يدعم خاصة التقسيم إلى 


لتفعيل هذه الخاصة يجب إعطاء القيمة 1۲٠٠‏ للخاصة ١2١عه٣‏ في النموذج الذي يحتوي عنصر التحكم ائا]. 

في حال تفعيل التقسيم الآلي إلى صفحات يجري تقسيم خرج القائمة إلى صفحات بحسب قدرة الإظهار الخاصة بالجهاز. 

أما في حال استعمال التقسيم المخصص إلى صفحات» فيجب إعطاء قيمة إلى الخاصة ٤١ا0٣‏ .ء)! لإعطاء العدد الكامل من العناصر 
الذي يمكن إظهاره عبر كل الصفحات. 

يقوم عنصر التحكم بالتقسيم إلى صفحات وعند طلب كل صفحة جديدة يجري إطلاق حدث كصع)]ل02]. 


مثال: 


يوضح المتال التالي هذه الفكرة: 
Page Inherits="MSPress.MobWeb.CusPag.ExampleWebForm" Language="c#"‏ @%5< 
CodeBehind="CustomPaginationExample.aspx.cs" AutoEventWireup=‏ 
"False" %>‏ 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 
Assembly="System.Web.Mobile" $%>‏ 
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<mobile:Form runat="server" id="Form1" paginate="true"> 
<mobile:Label runat="server" StyleReference="title"> 
Season 2003 results</mobile:Label> 

<mobile:List id="List1l" runat="server"></mobile:List> 


< MOA le SE OE ME 


: أما النص البرمجي في الخلفية فهو‎ 
using System; 
using System.Collections; 
USİiNG System.Web.UI. Mobi leControls; 


namespace MSPress.MobWeb. CusPag 
{ 
public class ExampleWebForm 
System.Web.UI.MobileControls.MobilePage 
{ 


private TeamStats[] _premierTable; 
protected System.Web.UI.MobileControls.List Listl; 


public ExampleWebForm () 

{ 
// In the constructor, create the data source we will use. 
_ premierTabl new TeamStats [16]; 
_ premierTabl = Mew leEamSE aE S (DURES, "BESE SOL); 
_ premierTabl new TeamStats ("Phoenix", E & £ 2 
_ premierTabl new TeamStats("Eagles", TEESE 
_ premierTabl new TeamStats("Zodiac", ME G8 


( 
( / 
( 
( 
_ premierTabl new TeamStats ("Arches", HIE © £ 
( 
( 
( 
( 


F۴ 
" 


r 
" 


_ premierTabl new TeamStats ("Chows", TEESE 


_premierTabl new TeamStats 
_premierTabl new TeamStats 
_premierTabl new TeamStats 
_ premierTabl = Mew leEamSEaAES ( General SL, EES. 
_ premierTabl = new TeamStats ("Reacti TEES: 
_ premierTabl 1 Hew TeamMStEatS( EeaANUE SL, BES: 
_ premierTabl E mew LEeESMSEAES (CAVE RS LL, TEES: 
_ premierTabl ] = new TeamStats ("1 1 FUEESS 

( 

( 


Crea ON, CEES 


TL UMS ORL, LEESS م‎ 


U 


SOG TIO EONS OI 


r 
" 


. 
r 
" . 
U 
" . 


r 


_ premierTabl 1 new TeamStats ("D , "PLS; م‎ 


_ premierTabl E mey lEeEAMSEAES( COSMOS, "EES A2 


r 


O) 
69) 
681) 
o6) 
61") 
S7) 
54) 
"Torpedo", TEES SA) 

S20) 
SNS) 
49") 
48") 
42) 
42 

) 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


1 


private void InitializeComponent () 


{ 
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this.Load += new System.EventHandler (this.Page_Load); 
this.lList1.LoadItems += 
new LoadItemsEventHandler (this.LOoadTeams) ; 
ا‎ 
private void Page_Load(Object sender, EventArgs e) 
{ 
// Tell the List how many items it can expect by the time 
// TE MAS asked FOE Ethem all 
List1.ItemCount = _premierTable.Length; 


1 


private void LoadTeams (Object source, LoadItemsEventArgs args) 


{ 


ISE. TEemMS. Clea (J, 
// The LoadItemsEventArgs tells us which items and how 


EOE (IME 1 > O; 1 éC AES IECMCSUME, UT) 
{ 
// Get the relevant item from the array; 
// Create a4 MOBI LELLSE LEM 
Int IintTablePosn = args.ItenIndex * 1; 
Mobile SEI Ee ISEIEeM — Hew MODI le Li SE I ECM ( 
SEE RE. HOMIE EO, {LFW ime lalOl EROS , 
_ premierTable[intTablePosn] .TeamName) , 
_ premierTable[intTablePosn] .Stats); 


1 2d Ehe item EO Ee lECMS COlLECENL ON OE ERE LISE 


CORE EOL. 
Listl.Items.Add(1stItem) ; 


class TeamStats 


{ 


private String teamName, stats; 


public TeamStats (String teamName, String stats) 
{ 


this.teamName = teamName; 
ERS SEAES < SEES, 


public String TeamName 
{ get { return this.teamName; } } 


BUSI SEEING SEAS 
1 GCE {[ FEUD ENIS. SEAES;, J | 
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تكون نتيجة تنفيذ هذا المتال شبيهة بالشكل التالي: 


عناصر تحكم القائمة 
عنصر تحکم ائ 


يشبه هذا العنصر عنصر تحكم ائ" ]ءام الذي قمنا بمناقشته سابقاًء بفرق أن عنصر التحكم ئ11 يدعم عملية تقسيم خر ج القائمة 
إلى عدة صفحات مما يقدم فائدة كبيرة في حالة القوائم الطويلة على الأجهزة المحمولة ذات شاشات الإظهار المحدودة الإمكانيات. 


يمكننا استخدام هذا العنصر أيضاً في حالة الرغبة بعرض قوائم تفاعلية وغير تفاعلية. في حالة القوائم التفاعلية لسنا بحاجة إلى زر 
خاص لعملية إرسال البينات إلى المخدم» إذ يتولى عنصر التحكم هذا عملية إرسال البيانات لدى النقر واختيار أحد العناصر. 


يدعم عنصر التحكم ء11 القوالب مما يجعل عنصر التحكم هذا مناسباً في حالة برمجة الاستجابات المتعددة المرتبطة بنوع الجهاز 
المستخدم. 


استخدام عنصر التحكم كا1 : 


ذكرنا سابقاً أنه يمكن استخدام هذا العنصر بوضعيتين: 


- الوضعية غير التفاعلية: يتم في هذه الوضعية إظهارعناصر القائمة دون القدرة على الاختيار. يمكن هنا تحديد شكل الإظهار 
باستخدام الخاصة ١0۲310٥ع.‏ ويجب عدم تحديد قيمة لمعالج الحدث 4١0۳1(2٣”ع]]‏ في هذه الحالة. 
الوضعية التفاعلية: في حال تم تعيين قيمة لمعالج الحدث أ١هد٣إه٣٣‏ .ع1 يجري تحويل كل عنصر من عناصر القائمة 
لرابط يقوم باستدعاء معالج الحدث عند النقر عليه. 


التقسيم إلى صفحات بصورة آلية أومخصصة: 
بعكس عنصر التحكم اءاا,هناءمام؟ يتحدر عنصر التحكم هذا من الصف 1١0إ٤«ه٣4ءعه۴‏ أي أنه يدعم خاصة التقسيم إلى 


لتفعيل هذه الخاصة يجب إعطاء القيمة 1١٠٠‏ للخاصة ١2”عه"‏ في النموذج الذي يحتوي عنصر التحكم ائ]. 

في حال تفعيل التقسيم الآلي إلى صفحات يجري تقسيم خر ج القائمة إلى صفحات بحسب قدرة الإظهار الخاصة بالجهاز. 

أما في حال استعمال التقسيم المخصص إلى صفحات» فيجب إعطاء قيمة إلى الخاصة اداه ٣‏ .]1 لإعطاء العدد الكامل من العناصر 
الذي يمكن إظهاره عبر كل الصفحات. 

يقوم عنصر التحكم بالتقسيم إلى صفحات وعند طلب كل صفحة جديدة يجري إطلاق حدث كصع)1ك04]. 
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عناصر تحكم القائمة 
عنصر تحکم 0bj‌ec)1s)‏ 


يعتبر هذا العنصرء عنصراً شديد المرونة هدفه الأساسي إظهار حقل واحد من مصدر بيانات كقائمة أساسيةء وعند اختيار المستخدم 


أحد عناصر هذه القائمة يقوم بإظهار حقول عديدة أخرى. 


بالإضافة إلى ماسبقء يوفر عنصر التحكم ميزة تتعلق بالأوامر التي يمكن ربطها بكل عنصر في القائمة. يمكن أيضاً ربط هذه القائمة 
بعناصر قائمة أخرى تختلف بحسب العنصر الذي تم النقر عليه. كما هي الحال مع عنصر التحكم اا1 يدعم عنصر التحكم 
stاjec1ط0‏ القوالب والتقسيم إلى صفحات. 


توضح الصيغة التالية استخدام عنصر التحكم هذا: 

<mobile:ObjectList 

runat="server" 

e Lhe 

Alignment=" {NotSet |Left|Center|Right}" 

BAC COLO = MIOELE le OE OUANCCOINL EOE 

Font-Bold="{NotSet|False| True}" 

ORE NlEaAlIECE={NOESEE Eal Se  UEUe 

Font-Name="fontName" 

Font-Size=" {NotSet |Normal | Small| Large}" 

ForeColor="foregroundColor™ 
StyleReference="StyleReference"™ 
Wrapping=" {NotSet |Wrap |NoWrap}" 


AutoGenerateFlields=" {True |False}" 
CommandStyle="StyleReference"™ 
DataMember="dataMember" 
DataSource="dataSource"™ 
DefaultCommand="onDefaultCommandHandler" 
ECM COUME = 1 ECEM CORE 
LabelField="fieldname™" 
LabelStyle="StyleReference™ 
OnItemDataBind="onItemDataBindHandler" 
OnItemCommand="onItemCommandHandler" 
OnLlLoadItems="loadItemsHandler"> 
OnShowItemCommands="onShowItemCommandsHandler"™ 
NableEieldS> EAB lee NASE 


<!-- Optional explicitly declared fields 
<Field 
1d="1id" 

Title="titleText"™ 
DataField="value" 
FOEMOCSLIIDNG=TEOIMALSETINGT 
ViSsible="{True|Ealse}!" /> 

</Field> 
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<1 =- OBEIORaAL eExPliei Ely Gecelared COMmanads > 
<Command Name="CommandName" Text="CommandText" /> 


</mobile:ObjeclLiISTE> 


يوضح الجدول التالي أهم الخصائص والأحدات التي يقدمها عنصر التحكم هذا: 

الخاصة أوالحدث النمط الوصف 

تعيد هذه القيمة غرض 
ObjectListFieldCollection‏ 

0b ject List Field‏ .لکل حقل یتم 
إضافته من مصدر البيانات إلى عنصر 


1 System.Web.UI. 
التحكم )ءءء زط0 سواء تم تعريفه‎ MobileControls. 
أوبواسطة‎ >۴1٥14< باستخدام التأشير ة‎ | jet ListFieldCollection AllFields 


الخاصة ل1٥٤۴‏ ضمن النص البرمجي . 
يمكنك أن تستخدم خصائص الحقول 
المحتواة لكن لن تستطيع إضافة أوإزالة 
حقل من هذه المجمو عة 
TruelFalse AutoGenerateFields‏ تقوم بإعداد عنصر التحكم لإظهار جميع 
الحقول من غرض 1ع5ه)ه5. 

تقوم بتعيين أوإعادة النص المستخدم 
ضمن الرابط الخاص بالعودة من إظهار 
التفاصيل إلى القائمة الرئيسية. 


BackCommand Text 


تقوم بإعادة غرض 
ObjectListCommandCollection‏ 


System.Web.UI.‏ حیٿ يوجد غرض 
MobileControls. ObjectList- Commands‏ 


andےmm‏ 0ل 0b ject List‏ ضمن هذہ 
Command-Collection‏ 1 


المجموعة لكل عنصر يعرف بالتأشيرة 
<لمaمصصهء>‏ يتم إضافته إلى النلص 
البرمجي . 

تعيين هذه الخاصة النمط المستخدم 
نمط صالح من الأنماط المستخدمة | لإظهار عناصر الأوامر على الأجهزة. 
CommandStyle‏ في لا يتم تخزين هذه الخاصة تلقائيا بين 
StyleSheet‏ الطلبات لذلك يجب ضبطها مع کل طلب 
والطريقة الأفضل لذلك هي تعريفها 


5 » يغة ۰ ال“ < من جهة 
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DataMember 


DataSource 


DefaultCommand 


Details 


DetailsCo mmandText 


System.Web.UI. 
MobileControls.Panel 


المخدم 2 


5 تخدم فقط عندما یکون . اأتح> 


مرتبطا بغرض 044861 أوغرض 


ما t42‏ . تحدد هذه الخاصة اسم 
الجدول ضمن غرض 1ء45( الذي 
سيتم ربط عنصر التحكم به. 
اسم الغرض 486( أوغرض 
ect‏ الذي یشکل مصدر 
البيانات 
تظهر القائمة بشكل تلقائي قيمة العنصر 
المحددة بالخاصة 12٤1۴٤14‏ على 
شكل ارتباط تشعبي. اختيار هذا 
الارتباط سيأخذ المستخدم إلى شاشة 
أخرى تظهر حقول إضافية لهذا 
العنصر. 
إذا تم تعيين الخاصة 
Default Command‏ ضمن النص 
البرمجي فإن عملية اختيار عنصر من 
القائمة سيقوم بإطلاق الحدث 
andےOntemC0mm‏ مع تمریر قیمة 
الخاصة هذه إليه. مع العلم أنه سيظل 
بإمكاننا الوصول إلى تفاصيل العنصر 
من خلال الوصلة 10۲١‏ والتي تظهر 
بمحاذاة الوصلات إلى أي عناصر أوامر 
أخرى قمت بتعريفها. 
تقوم هذه الخاصة بإعادة عنصر تحكم 
1 المستخدم في إظهار تفاصيل 
العناصر . هذه الخاصة عملية عندما تقوم 
بتطبيق القوالب وتريد تعيين خصائص 
عنصر التحكم الذي قمت بوضعه ضمن 
القالب. 


ObjectList1.Details 
.FindControl(ControlIlD”); 


تقوم هذه الخاصة بتعيين أوإعادة النص 


شاشة التفاصيل. تستخدم هذه الخاصة 
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مع مستعرضات ۷MN1‏ فقط. 
تشبه هذه الخاصة الخاصة 1۶ع ۸11۴. 
حيث تقوم بإعادة غرض 
0bjectListFieldCollection‏ الذي 
يحتوي غرض 14عec†1s)۴1ز0b‏ لکل 
حقل في مصدر البيانات تمت إضافته 
إلى عنصر التحكم ءءء زط0 الذي 
تم تعریفه باستخدم التأشیر ة <1dع۴>‏ 
أوعن طريق النص البرمجي باستخدام 
الخاصة ءل1ع۴. 
بعكس الخاصة 1۶ع ۸11۴ المعدة 
للقراءة فقط يمكن بواسطة هذه الخاصة 
إضافة وإزالة حقول باستخدام طرق 
الغرض 
ObjectListFieldCollection‏ 
تستخدم هذه الخاصة في حالة التقسيم 
المخصص إلى صفحات بحيث تحدد 
العدد الكامل للعناصر ضمن مصدر 


.0a)a8e البيانات‎ 


ObjectListFieldCollection Fields 


Integer ItemCount 


لاستخدام هذه الخاصة يجب ألا ننسى 
ضبط خاصة Form.Paginat‌e‏ إلى 
القیمة ue‏ 

تحدد اسم الحقل في مصدر البيانات الذي 
سیتم استخدامه کدليل أساسي. 
حقل الدليل الأساسي يزود القائمة التي 
ستظهر للمستخدم ويقوم فيها باختيار 
العنصر لتظهر تفاصيله. 

LabelFieldIndex ةصاخll تقوم‎ 


LabelField 


بتقديم نفس الفعالية ولكن تحدد الدليل 
ضمن المجمو عة ئل1ع۸11۴i‏ 
تقوم بإعادة أوتعيين النمط المستخدم 
لإظهار الترويسة. هذه الخاصة لا تحافظ 
OT LabelStyle‏ ت المت ٠‏ 5 تلف 
على قيمتها بين الطلبات المتكررة بذلك 
فالحل في المحافظة على قيمة ثابتة 


هوتعريفها ضمن صيغة عنصر التحكم 
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MoreText 


SelectedIndex 


Selection 


TableFields 


ViewMode 


String 


Integer 


System.Web.UI. 
MobileControls. 
ObjectListItem 


String; 
قائمة من أسماء الحقول مفصولة‎ 
بفاصلة منقوطة‎ 


System.Web.UI. 
MobileControls. 
ObjectListViewMode 


ListlCommandslDetails 


من جهة المخدم. 

تقوم بتعيين أوإعادة النص المستخدم 

للرابط [101e‏ على مستعرضات 
HTML‏ . 

تقوم بإعادة أوتعيين الدليل للعنصر 

المختار. 


تقوم بإعادة العنصر المختار أوالقيمة 


إذا لم تقم بتعيين قيمة للخاصة 
e۴46‏ اه" سيتم إظهار القائمة على 
أنها مكونة من عمود واحد يتكون فقط 
من قيم الحقل المحدد بالخاصة 
.LabelField‏ 


Default command‏ وکان الجھاز 

يدعم الجداول سيتكون هذا العمود من 

قيمتين الأولى هي قيم الحقل المحدد 

بالخاصة 14ء141۴ إضافة إلى 

الرابط .More‏ 
إذا قمنا بإعطاء قيمة للخاصة 

"able 46‏ سیتم تمثیل کل عنصر 

من القائمة باستخدام جدول مع الأعمدة 

المعرفة بالحقول ضمن هذه الخاصة 

إضافة إلى حقل تظهر فيه M0۲6‏ لتسمح 

بالوصول إلى رؤية جميع الحقول 
الخاصة بالعنصر. 

تسمح هذه الخاصة بتعيين وضع المعاينة 

للعنصر ء1 اء زط0 .يمكن أن تأخذ 
هذه الخاصة القيم: 

- ا1ا التي تقوم بإظهار 

عناصر القائمة الرئيسية فقط. 

- كانه)ع( تقوم بإظهار تفاصيل 

العنصر المختار. 

Commands ¬‏ یتم إِظھارھا 
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ItemCommand انحدث‎ 


LoadItems الحدث‎ 


ShowlItemCommands انحدث‎ 


اسم طريقة معالج الحدث 


اسم طريقة معالج الحدث 


اسم طريقة معالج الحدث 


فقط على الأجهزة ذات 
الشاشات الصغيرة كالهو اتف 
المحمولة وهي الشاشة الأولى 
التي يتم عرضها بعد اختيار 
المستخدم لعنصر ما حيث 
تظهر قائمة تتكون من عناصر 
>Cc0mmand<‏ إضافة إلى 
روابط إلى المعاينة التفصيلية. 
على المستخدم اختيار عنصر من القائمة 
قبل السماح له بالوصول إلى الخاصة 
ViewMode‏ 


يحدد معالج الحدث الذي سيتم استدعاؤه 

عندما يقوم المستخدم باختيار عنصر من 

الأوامر المرتبطة بإظهار تفاصيل أحد 
العناصر. 


يتم تعريف الأوامر باستخدام التأشيرة 


<dصma 0m‏ > أومن خلال التعامل مع 
المجموعة التي تحددها الخاصة 
Commands‏ 


هذا الحدث مطلوب حين يتم تعيين 
الخاصة ٣01٣٤‏ .ع]] لتفعيل التفقسيم 
المخصص إلى صفحات. يقوم التطبيق 
باستدعاءِ معالج الحدث هذا في کل مرة 
یتم طلب بیانات جديدة. سمح هذا 
الحدٿث بتمرير البيانات إلى عنصر 
التحكم خبت الطلي عرض خن قري 

كل البيانات دفعة واأحدة. 

يحدد معالج الحدث الذي يتم استدعاؤه 
وتشكيل الوصلات الخاصة بالأوامر. 
في معالج الحدث هذا يمكن إضافة 


للعنصر الذي یتم إظهاره. 
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استخدام عنصر التحكم {s٤ecزط0b:‏ 
يمكن عنصر التحكم هذا من أداء مجموعة من الأعمال تفوق ما يمكن أن يؤديه عنصر التحكم ائز1. 
أهم الوظائف التي يمكن لعنصر التحكم هذا القيام بها ولا يمكن تأديتها من خلال عنصر تحكم ائ هي: 
1- إظهار عدة حقول من مصدر بيانات. 
2- إظهار العناصر ضمن جدول عوضاً عن إظهارها كقائمة من عمود واحد. 
تزويد أكثر من أمر مرتبط بنفس العنصر من القائمة. 
تزويد عدة أوامر للخيارات المتعددة من القائمة. 
إظهار حقل وحيد مع إمكانية إظهار عدة حقول كوظيفة ثانوية. 


لتوضیح کل من هذه المیزات سنقوم باستخدامها ضمن مثال خاص: 
1- إظهار عدة حقول من مصدر بيانات: 


Page Inherits="MSPress.MobWeb.ObjListEx.MyWebForm" Language="c#" 
CodeBehind="ObjectListExample.aspx.cs" AutoEventWireup="False" $%> 
Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


MOONEE EOE EUNAES Se EEL 
<mobile:Label runat="server" StyleReference="title"> 
Season 2003 results</mobile:Label> 
<mobile:ObjectList id="ObjectList1" runat="server"> 
AutoGenerateFields="false"> 
<Field Title="Team" DataField="TeamName"></Field> 
<Field Title="Won" DataField="Won"></Field> 
<Field Title="Drawn" DataField="Drawn"></Field> 
WISN iE LE=WLOSEY Dila IENE WLOS EH < RTE LES 
<Eield ME lees DalaBield=LEPOIANESL Vi SIGE LEAN Se LS < E1 e1 A> 
</mobile:ObjectList> 
</mobile:Form> 


أما النص البرمجي في الخلفية فهو : 


using System; 
UST ME SUSE . COLLEGE 1 OAS 
USING SYSTEM. WED. UL. MobDilECoNTrOLS;, 


namespace MSPress.MobWeb.ObjListEx 
{ 
public class MyWebForm : System.Web.UI.MobileControls.MobilePage 
1 
protected ObjectList ObjectListl; 


override protected void OnInit (EventArgs e) 
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InitializeComponent () ; 
base. ONIN E (e), 


} 


private void InitializeComponent () 
ا‎ 
this.Load += new System.EventHandler (this.Page_Load); 


} 


private void Page_Load(Object sender, EventArgs e) 
{ 

iE (ITSEOSEBAEK) 

{ 


ArrayList array = new ArrayList () j 

array.Add (new TeamStats ("Dunes",1,38,24,8,6,80)); 
VENOCERAxX LL, 2,307 2O, OE, LOE 
) 
) 


array.Add (new TeamStats ( 
dE AY. Add (Rew UeamotaltSs (I BHaGIleSL, 5, 90, 20,9, 9,09) 
aACEAY AAS (Rew Team SEaE S (IZOduaCe Ll, 4,09, 20, O8 


7 


ObjectList1.DataSource = array; 
ObjectList1.LabelField = "TeamName"; 
ObjectList1.DataBind(); 


class TeamStats 
{ 
private String _teamName; 
OEIWEES ME _ OSI EIOM, _OIESMEC, WON, _ CCEA, __ OSE, __ OLE 


public TeamStats (String teamName, 
IPE OoSIEICN, 

int played, 

won, 

drawn, 

OSE, 

POAME SJ) 


._ tLteamName = teamName ; 
SPOS EELON = POS ENON, 
._played = played; 

._ WON = Won; 

SS Ira — GAWA, 
NOSE > LOSE, 

SS. BPOANES = POPOUNES, 


E E TT 
0 0 0O 0 


n 


} 


public String TeamName { get { return this._teamName; } } 
OuUOLTE ME POSIEION {| GEE { TEEN EMIS ._OOSI ELON J | 
OUOLIE 1ME Played OEE (1 TeEEUEN ERIS. Blaved; I | 
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1 E US LE WOME 
return LE o CEE 
return SEO SE, 

return MS POLES, 


2- إظهار العناصر ضمن جدول عوضا عن إظهارها كقائمة من عمود واحد. 


<%5@ Page Inherits="MSPress.MobWeb.ObjListTbLEx.MyWebForm" Language="c#" 
CodeBehind="ObjectListTableExample.aspx.cs" AutoEventWireup="False" 
$> 
<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


MOON LE $ FOS EUDEE =F SEE WEE 
<mobile:Label runat="server" StyleReference="title"> 
Season 2003 results</mobile:Label> 
<mobile:ObjectList id="ObjectList1" 
runat="server" 
AutoGenerateFields="true" 
Table ielGdS leamName; EOSIEION; EOINES LY 
</mobile:ObjectList> 
SVmMOBA NE E SEMS 


3- تزويد أكثر من أمر مرتبط بنفس العنصر من القائمة. 


<%@ Page Inherits="MSPress.MobWeb.ObjListCmdsEx. MyWebForm" 

Language="c#" 
CodeBehind="ObjectListItemCommandsExample.aspx.cs" 
AutoEventWireup="False" %> 

<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls"™ 
Assembly="System.Web.Mobile" $%> 


MOON LE SEOEM EUNAE= SCE VEEN MSA MOM LS 
<mobile:Label runat="server" StyleReference="title"> 
Season 2003 results</mobile:Label> 
<mobile:ObjectList id="ObjectListl1" runat="server" 
AutoGenerateFields="false" 
LabelField="TeamName"> 
<Field Title="Team" DataField="TeamName"></Field> 
<Field Title="Won" DataField="Won"></Field> 
<Field Title="Drawn" DataField="Drawn"></Field> 
Ei eld MME le =ILOoOSEL Data elGA< LLOSE LS GEN e IOS 
<Field Title="Points" DataField="Points"></Field> 
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<Fiel i1tle="Champs. Cup" DataField="ChampionsCup™ 
1isible="false"> 
</Field> 
<Eield Title INEEE CIEY CUP. Data iel dL UNECE CUSL 
Visible="false"> 
</Field> 
<Uommand Name="ChampsCup" Text="Chanpions Cup" 
<Command Name="InterCityCup" Text="Inter-City Cup"/> 
</mobile:ObjectList> 
</mobile:Form> 


<mobile:Form runat="server" id="EForm2"> 
<mobile:Label runat="server" StyleReference="title"> 
Season 2003 European Results</mobile:Label> 
<mobile:Label runat="server" id="Label1"/> 
<mobile:Link runat="server" NavigateUrl="#Form1"> 
Back 
</mMObDIlE LINK 
</mobile:Form> 


أما النص البرمجي في الخلفية فهو : 


using System; 
using System.Collections; 
USING SYSTEM. WEDS. UL. MODILECONTEOIS; 


namespace MSPress.MobWeb.ObjListCmdsEx 
{ 
public class MyWebForm : System.Web.UI.MobileControls.MobilePage 
1 
protected ObjectList ObjectListl; 
protected Form OEM Z f 
protected Label Label1l; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


private void InitializeComponent () 
1 
this.Load += new System.EventHandler (this.Page_Load) ; 
this.ObjectList1. ItemCommand += 
new 


ObjectListCommandEventHandler (this. Team_OnItemCommand) ; 


} 


private void Page_Load(Object sender, EventArgs e) 


1 
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1f (IISEOSEEBACKE) 
1 

ArrayList array = new ArrayList (); 

array.Add (new TeamStats ("Dunes",1,38, 24,8, 6,80, 
"Oar ter Eimal sS, OD) 
array.Add (new TeamStats ("Phoenix",2,38,20,10,8, 70, 
"ODart EEE EinalSl, CT), 
aA YY Add (Rew UeamMSEatES ( EG LES, 9, 0, 2O, I, OOO, 
MM "Winners" )) ; 
AEE AV AAS (Rew Team SE aE S (AOA a cel, 24, SS, 20, CIO, OO, 

"Sems Ema LS LS 


ObjectList1.DataSource = array; 
ObjectList1.LabelField = "TeamName"; 
ObjectList1.DataBind(); 


} 


private void Team_OnlItemCommand ( 
Object sender, 
ObjectlListCommandEventArgs e) 


Label1.Text = "Did Not Compete"; //Default 
EDS ACEI UCEOEM < HOE, 


1f (e.CommandName == "ChampsCup") 
{ 
// Set the label to the Champions Cup result. 
if (e.ListItem["ChampionsCup"] != "") 
Label1.Text = "Champions Cup: " + 
e.ListlItem["ChampionsCup"] ; 


1f (e.CommandName == "InterCityCup") 


/ Set the label to the Inter-City Cup result. 
iE (CE. LISELEeMI| LINECFCUG LL) 1> LT) 
Labell.TeEzt = ' Ilr CIETY CUB: FF ¢ 
e.ListlItem["InterCup"]; 


class TeamStats 

{ 
private String _teamName; 
PEA EE AME OOSTHEN ON, Plaved, MON, CHAM, OSE, DOMES, 
BPEIvVaEe SELINS CENaMOSCUS, MNEerCUD; 


public TeamStats(String teamName, 
INE pOSiLIOnN, 
int played, 
1ME WOM, 
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CUD 


return this._teamName; }} 
eM ENS OOS EN OM; JF 
return this._played; }} 

EE UE ES. MOM lJ 

FE EUEN ERIS. Sra; Il 

FEE ENIS. ISE? | 

TEE ULM EMM S_OOLNESS 1 

E {1 EE UEN EAL SS. CMSMOSCEUD, FF 


4- تزويد عدة أوامر للخيارات المتعددة من القائمة. 


1 ME CAW, 

E OSE, 

IME POINES, 

Sie E 1 AE, CASS OASECUS 
SEEING INECTCUD) 


E 
Eh 
i 
th 
ih 
E 
Li 
Eh 


._ teamName = teamName ; 
u OOSLEI ON — OOS E LOM; 
._played = played; 

._ WON = WON, 

ا کس ا اہ 

IOS LOSE; 

pPOINES = OPONMES; 

._ champsCup = champions 
_ interCup= interCup; 


U V0 0O U oO U 0O o vw 


ing TeamName { get 
EOSIEION { Gel 
Played { get 
Won { get 
Drawn { get 
LOS { get 
Points { get 


BPUOILiEGE SEEING ChamSi ONSEUSE {| Ge 
PUDDLE SEIN InEeFCEUPD Cel (| EEEUN EOAS, INECEFCUS, | 


<%5@ Page Inherits="MSPress.MobWeb.ObjListShowItems.MyWebForm" 


ample.aspx.cs" 


ON SE 


= 


erence="title"> 


runat="server" 


Language="c#" 


CodeBehind="ObjectListOnShowItemsEx 
AutoEventWireup="False" %> 

<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileCont 
Assembly="System.Web.Mobile" %> 


E OEM LE 


AutoGenerateFields="true" 
LabelField="TeamName"> 
<Command Name="ChampsCup" Text="Chanmpions CuUB™"/> 
<Command Name="InterCityCup" Text="Inter-City Cup"/> 
</mobile:ObjectList> 
</mobile:Form> 
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MOONEE EOEM EUG ESL SEE VE RL 
le:Label runat="server" StyleRe 
Season 2003 results</mobile:Label> 
le:ObjectList id="ObjectList1™ 


<mob i 


<mob i 


<mobile:Form runat="server" id="Eorm2"> 
<mobile:Label runat="server" StyleReference="title" id="Label1"/> 
<mobile:Label runat="server" id="Label2"/> 
<mobile:Link runat="server" NavigateUrl="#Form1"> 
Back 
</mobile:Link> 
</mobile:Form> 


والنص البرمجي في الخلفية يأخذ الشكل: 


USING SYSEeN; 
STE SUSE. COLLECE OAS 
using System.Web.UI .MobileControls; 


namespace MSPress.MobWeb.ObjListShowItems 
{ 
public class MyWebForm : System.Web.UI.MobileControls.MobilePage 
{ 
protected ObjectList ObjectListl; 
protected Form O MZ f 
protected Label Label1l; 
protected Label Label2; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


} 


private void InitializeComponent () 

{ 
this.Load += new System.EventHandler (this.Page_Load) ; 
this.ObjectlList1. ItemCommand += new 


e 


ObjectListCommandEventHandler (this. Team_OnItemCommand) ; 
this.ObjectList1.ShowItemCommands += new 


ObjectListShowCommandsEventHandler (this. SetItemCommands) ; 


} 


private void Page_Load(Object sender, EventArgs e) 
{ 

// Not shown 

// As in previous example 


private void Team_OnlItemCommand ( 
Object sender, 
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ObjectlListCommandEventArgs e) 
EDS. ACEM VEE OEM = HOE, 


if (e.CommandName == "ChampsCup") 
{ 

// Set the label to the Champions Cup result. 
Labell1.Text = "Champions Cup 2003"; 
Label2.Text = e.ListItem["ChampionsCup"™] ; 


} 
else if (e.CommandName == "InterCityCup") 
{ 

// Set the label to the Inter-City Cup result. 
Tabell. Text = Inter CIEY CUPS 2O0, 
Label2.Text = e.ListItem["InterCup"]; 


} 


private void SetItemCommands ( 
Object sender, 
ObjectlListShowCommandsEventArgs e) 


// Remove either the Champions Cup or Inter-City Cup 

// command if the team didn't compete lif fIEld 1s Blank}. 

if (e.ListItem["ChampionsCup"] == "") 
e.Commands . Remove ("ChampsCup") ; 


if (e.ListItem["InterCup"] == "") 
e.Commands. Remove ("InterCityCup") ; 


} 


class TeamStats 

{ 
private String _teamName; 
BPEIaAEE OME OOS EN ON, lave d, MON, OAM, OSE, OOINEST, 
BPEIvVaEe SERINS CEMaMPSCEUS, AnEerCEUD; 


public TeamStats (String teamName, 
INL poOSILION, 

int played, 

E WOM, 

int drawn, 

E LOE 

INE POIRLES, 

Sie E 1 AC, CASON ONSEN 

SEEING INECTCUD) 


this._teamName = teamName; 
ELE o__OOSLE LOM BOS EA OR; 
this._played = played; 
ERN S. WOM — WOM, 
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عنصر تحکم )ء)ec‌jط0b:‏ 
عنصر التحكم هذا هوعنصر شديد المرونة هدفه الأساسي إظهار حقل واحد من مصدر بيانات كقائمة أساسية وعند اختيار المستخدم 


أحد عناصر هذه القائمة سيقوم بإظهار حقول عديدة أخرى. 

بالإضافة إلى هذا يوفر عنصر التحكم ميزة تتعلق بالأوامر التي يمكن ربطها بكل عنصر في القائمة. يمكن أيضا ربط هذه القائمة 
بعناصر قائمة أخرى تختلف بحسب العنصر الذي تم النقر عليه. 

كما هي الحال مع عنصر التحكم ء11 يدعم عنصر التحكم ءءء زط0 القوالب والتقسيم إلى صفحات. 
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القسم التاسع والعاشر: 


الموضوع الثالث: عناصر التحكم المُخصَصة 


الكلمات المفتاحية: 


عنصر تحکم»› محمول» لغة تأشيرء تأشيرة» واصفة» خاصة» حدث. 


کر فى وذ الح ى فة القال مخ جن غتاض لتك المخصصة ولي فة إعادها راهم الزات ال تا 
ستغطي هذه الجلسة عناصر MobileDynamicImageControl «MobileMultiLineInput «MobileCheckBox p5‏ 


أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على: 
° ieصر‏ llتھpS MobileCheckBox‏ 
ieصر‏ تكم MobileMultiLineInput‏ 


.MobileDynamicImageControl pS رصie‎ 
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استخدام عناصر التحكم المخصصة 


تتضمن الكثير من المواقع ومنها ع١.مpكه.wس»//‏ :م1)1 العديد من عناصر التحكم التي تم بناؤها من قبل مطورين» والتي لا تنتمي 
لئ مجموعة عناصر التحكم التي تقدمها ASP.NET Mobile‏ فکیف سنقوم باستخدام هذه العناصر ضمن تطبيقاتنا. 


في حال استعمال :Visua] Studio‏ 


في حال استعمال بيئة التطوير الخاصة i0لنا؟‏ 21٠ء۷1‏ يكفي لإضافة هذه العناصر اتباع المراحل التالية: 
MobileCheckboxExample - Microsoft Yisual C# .NEI [des‏ 39 
File Edt View Project Build Gebug Data Format Table‏ 


Delete Tab 


Rename Tab 


0 1 


Sart Items Alphabetically 


TExXEBOx List izi 


TexkYieyy Add Tab 
Command 
Link 

Phonecall E BE 


Show All Tabs 


Image Mowe: Dori 


List 


SelectionList 
ObjectList 
DeviceSpecific 
Stylesheet 

Calendar 

1 AdRotator 

[= RequiredFieldYalidator 


Ey, Comparevalidator 


E ê & î Hm E Fe E WM Iz CAZ 


4# 


Tyr Rangevalidator 


[#y RegularExpressionYalidator 


Customnvalidator 


YalidationSurnmary 


Universal Knowledge Solutions s.a.1 
162 


Customize Toolbox 


COM Components .MNET Framework Components | 


Name 1 Namespale |_ Assembly Name 

AdRotator System, Web, UL.Mobiletont,,, System.Web, Mobile ¢1,0,3300,0} 

AdRatator System, Web, UI.'WebContrals System, web {1,0,3300,0} 

O BssemblyInstaller System, Configuration, Install System, Configuration, Install (1,0,3300... 

Button System, Windows, Forms System, CF. Windows, Forms (1,0,3300,0} 

Button System, Windows, Forms System, Windows, Forms (1,0,3300,0} 

Button System, Web, UI'WebContrals S¥stem, Web {1,0,3300,0} 

OButtonarray Microsoft, YisualBasic Comp... Microsoft, YisualBasic, Compatibility (7.0.., 

calendar System, Web, UL.MabileCont,,, System, Web, Mobile {1,0,3300,0} 
System, Web. UIwebControls S¥stern, Web f1, 


j theckbox 
BFOWSE,.. 
4 Language: Invariant Language (Invariant Country} ت‎ 


Yersion: 1.0.923,26200 {Retail} 


Lancel أ‎ Reset أ‎ 


أما في حالة عدم استخدام بيئة التطوير 0نأtu؟S‏ اوuئز۷‏ : 
يجب في هذه الحالة نسخ الملفات التجميعية ضمن المجلد ١1ط/‏ الخاص بالتطبيق ومن ثم إضافة المرجع إلى بداية ملف ×مكه. 


فمثلاً في حالة عنصر التحكم ×80 )ء1 ٣ء1زطه[‏ يكون التعبير المضاف من الشكل: 
Register TagPrefix="mobCB" Namespace="MobileCheckbox"‏ @%5< 
Assembly="MobileCheckbox" $%>‏ 


وبعدها يمكننا استخدام عنصر التحكم هذا بالصيغة 


MOONEE ACRE CEOS ME OMe KOON 1 EUMAEELSeEFE VEEL TC AMOOCEB CNEeE CEOS 


MobileCheckBox مpك<تll‎ رصiع‎ 


يقدم عنصر التحكم هذا آلية عنصر التحكم ×80 )٥ط‏ العادية مع إمكانية خاصة للعمل على مستعرضات CHTML «HTML‏ 
.WMLg‏ 


يبين الشكل التالي كيف يظهر عنصر التحكم هذا على المستعرضات المختلفة. 
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Emulator Help 


Facts about Wales 


Facts about Wales: 
Facts about Wales {™Ty, EOE 

Facts about Wales: Capital EAR 

rue or False? Highest mountain is Snowdon 
1 Capital is Cardiff OFa¥aorite sport is rugby 
OBghest mountain is Snowdon 

Favorite sport is rugby 

Next 


للاستفادة من عنصر التحكم هذا لا بد من إعداد تطبيقك من خلال إضافة <٥ءعل>‏ ضمن تأشير <eContr01sاmobi>‏ في ملف 


:web.config دIدعإلا‎ 
<CEONTIGUTAEION 
<Ssystem.web> 
<mobileConirolss 


<device name="MobileCheckboxHtmlDeviceAdapter" 
inheritsFrom="HtmlDeviceAdapters"> 
ESRÊ ON mame MODA LECCE. CRECKBOxS, MOON TE CRECKEOOS 
adapter="MobileCheckbox.HtmlCheckboxAdapter, MobileCheckbox"/> 
</device> 
<device name="MobileCheckboxWmlDeviceAdapter" 
inheritsFrom="WmlDeviceAdapters"> 
<EONEr Ol name=IMobDı leclCheckbBOx< . Checkbox, MODI I eECNhEeECKDOX 
adapter="MobileCheckbox.Wm1lCheckboxAdapter, MobileCheckbox"/> 
</device> 
<device name="MobileCheckboxChtmlDeviceAdapter" 


inheritsFrom="ChtmlDeviceAdapters"> 
EOREEON mame MODA lECRECASOS. CMECK BOS, MOON le CRECKOOS 


adapter="Mobi leCheckbox.ChtmlCheckboxAdapter, MobileCheckbox"/> 
</device> 


UMEDA NECOME EONS 
</system.web> 
< /EONE LOE EAE LORS 


يستخدم عنصر التحكم هذا الصيغة التالية: 
Register TagPrefix="mobCB" Namespace="MobileCheckbox"‏ @%5< 
Assembly="MobileCheckbox" $%>‏ 


TMOOCECREECEKR OOS 
runat="server" 
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س 
Alignment="{NotSet|Left|Center|Right}"‏ 
BackColor="backgroundColor™‏ 
BreakAfter=" {True|False}"‏ 
Font-Bold="{NotSet|False| True}"‏ 

EOE lEal1 C= NOE SEE Eal Se | Ur Ue 
Font-Name="fontName" 
Font-Size=" {NotSet | Normal | Small | Large} " 
ForeColor="foregroundColor™ 
StyleReference="StyleReference"™ 
Wrapping=" {NotSet |Wrap | NoWrap}" 


AutoPostBack=" {True|False}" 
Checked=" {True|False}" 
OnCheckedChanged="EventHandlerMethodName™"™ 
TextAlign=" {Left| Right }" 
Text="LabelText" 

</mobCB:Checkbox> 


يبين الجدول التالي يبين الخصائص والأحداث التي يدعمها عنصر التحكم هذا: 
الخاصة أوالحدث النمط الوصف 


TruelFalse AutoPostBack‏ تقوم بتعيين أو إعادة القيمة التي تحدد 


فيما إذا كان سيجري إرسال حالة 
عنصر التحكم إلى المخدم عند النقر 
على هذاالعنصر .تكون القيمة 
التلقائية لهذه الخاصة هي عیاھ۴ 
ويمكن تطبيقها على مستعرضات 
H{im1‏ فقط. 
في حال كانت لهذه الخاصة القيمة 
6 نحتاج إلى وجود عنصر 
آخر ليقوم بعملية إرسال النموذج 
إلى المخدم. 
True | False Checked‏ تقوم بتعيين أوإعادة القيمة التي تحدد 
فيما إذا كان عنصر التحكم مختارا 
في الوضع البدائي. 
System. Web.UI.We TextAlign‏ يتم استخدام هذه الخاصة لتحديد 
bControls.TextAlign‏ 1 

محاذاة النص المرتبط بعتصر 
LeftlRight‏ التحكم. 


String‏ تستخدم هذه الخاصة لتعيين أوإعادة 
قيمة النص المرتبط مع عنصر 
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التحكم هذا. 
انحدث CheckedChanged‏ طريقة معالج الحدث تعيين اسم طريقة معالج الحدث 
حيث يتم إطلاق هذا الحدث عند 


تغيير قيمة الخاصة .Checked‏ 


المثال التالي يوضح استخدام عنصر التحكم هذا: 

Register TagPrefix="cc1" Namespace="MobileCheckbox"™ 

Assembly="MobileCheckbox" $%> 

Page language="c#" Codebehind="default.aspx.cs" 

Inherits="MSPress.MobWeb.CheckboxEx._ default" 

AutoEventWireup="false" %> 

Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 

Assembly="System.Web.Mobile" %> 


MOON NEE FOC AG VTOE MLS EUNAE = SE VEE ELE LE=YTACES AOOUE WALES > 
<mobile:Label i Label3" runat="server" StyleReference="title"> 
:</mobile:Label> 
TO i ê Ê I ACME Z# UAE =W SCE MOE WS 
True or False?:</mobile:Label> 
EE ll SCORSESE UES HCEMeEECkDO IY EUAN =H SAE EE 
Text="Uapilal 1S Cardiff" <(CCl:CNECKEDORZ 
CEC SCMEECKEOO AEOSCNEECkKOO2Y FEUD =F SEE EE 
Text="Highest mountain is Snowdon"></cc1:Checkbox> 
SEC IECREERDOS MA ENECROOSS LL EUMAE SE VEEL 
Text="FavVoOrIltêe SBPOEL 1S rugby =</ cel :Checkbox> 
<mobile:Command id="Command1" runat="server">Next</mobile:Command> 


< /mObi Le :EOEM> 


mol le EOE TOA HOMA CUNO E< SERVER. EAE E=IReESUIEL 
MOON Ne Label MAI VaDel IE EFUNAE = SCF VEE 
StyleReference="title">Result</mobile:Label> 
<mobile:Label id="result" runat="server">Label</mobile:Label> 
SVmMOBM le EOEMS 


أما النص البرمجي في الخلفية فهو : 


using System; 
USING SYSTEM. Web. UIL. MoBilEConiErols; 


namespace MSPress.MobWeb.CheckboxEx 
{ 
public class _default : System.Web.UI.MobileControls.MobilePage 
{ 
protected MobileCheckbox.Checkbox Checkbox1; 
protected System.Web.UI.MobileControls.Command Commandi1l ; 
protected System.Web.UI.MobileControls.Form Form2; 
protected MobileCheckbox.Checkbox Checkbox2; 
protected MobileCheckbox.Checkbox Checkbox3; 


Universal Knowledge Solutions s.a.1 
166 


protected System.Web.UI.MobileControls.Label result; 
protected System.Web.UI.MobileControls.Form Forml; 


override protected void OnInit (EventArgs e) 
1 

InitializeComponent () ; 

base.OnInit (e); 


} 


private void InitializeComponent () 


{ 


ELS. Commend l. CAC 4— 
new System.EventHandler (this.Command1_ Click); 


} 


private void Command1_ Click (object sender, System.EventArgs e) 
{ 

mE COTE > O; 

1f (Checkbox1.Checked) correct++; 

1f (Checkbox2.Checked) correct++; 

1f (Checkbox3.Checked) correct++; 


EFeSMIE. lexXE = VOU OSE 1 1 COFEECE.LOSEEINI() 4 1 COEEECEL; 


NEE I VEEFOEM  HOFMZ, 


يقدم عنصر التحكم هذا آلية عنصر التحكم ×80 )٥ط‏ العادية مع إمكانية خاصة للعمل على مستعرضاٽت CHTML «HTML‏ 
.WMLg‏ 


عiصر‏ llت<كp MobileCheckBox‏ 
يقدم عنصر التحكم هذا آلية عنصر التحكم ×K80عءءعطح‏ العادية مع إمكانية خاصة للعمل على مستعرضات CHTML «HTML‏ 
.WMLg‏ 
يبين الشكل التالي كيف يظهر عنصر التحكم هذا على المستعرضات المختلفة. 
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Emulator Help 


Facts about Wales 


Facts about Wales: 
Facts about Wales Te True or False?: 


Facts about Wales: HCapital is Cardiff 

tue or False?: MHighest mountain is Snowdon 
1 Capital is Cardiff OFavorite sport is rugby 
OBghest mountain is Snowdar 

Favorite sport is rugby 

Next 


Favorites 


للاستفادة من عنصر التحكم هذا لا بد من إعداد تطبيقك من خلال إضافة <٥ءعل>‏ ضمن تأشير <eContr01sاmobi>‏ في ملف 


:web.config دIدعإلا‎ 
<CEONTIGUTAEION 
<Ssystem.web> 
<mobileConirolss 


<device name="MobileCheckboxHtmlDeviceAdapter" 
inheritsFrom="HtmlDeviceAdapters"> 
ESRÊ ON mame MODA LECCE. CRECKBOxS, MOON TE CRECKEOOS 
adapter="MobileCheckbox.HtmlCheckboxAdapter, MobileCheckbox"/> 
</devicez> 
<device name="MobileCheckboxWmlDeviceAdapter" 
inheritsFrom="WmlDeviceAdapters"> 
<EONEr Ol name=IMobDı leclCheckbBOx< . Checkbox, MODI I eECNhEeECKDOX 
adapter="MobileCheckbox.Wm1lCheckboxAdapter, MobileCheckbox"/> 


</device> 
<device name="MobileCheckboxChtmlDeviceAdapter"™ 


inheritsFrom="ChtmlDeviceAdapters"> 
TEOREE ON mame IMO LECE CASOS. CMECK BOS, MOON TE CRECKOOS 


adapter="Mobi leCheckbox.ChtmlCheckboxAdapter, MobileCheckbox"/> 
</device> 


< Olo LECOME LON Sz 
</system.web> 
< EOE LEOUEEAE LORS 
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يستخدم عنصر التحكم هذا الصيغة التالية: 


<%@ Register TagPrefix="mobCB" Namespace="MobileCheckbox" 
Assembly="MobileCheckbox" $%> 


<mobCB:Checkbox 
runat="server" 
1d="1id" 
Alignment=" {NotSet |Left|Center|Right}" 
BackColor="backgroundColor™ 
BreakAfter=" {True|False}" 
Font-Bold="{NotSet|False| True}" 
EONE - lEal1C=" {NOESEeE | Ealse | TEUEe } 
Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small | Large} " 
HOE e CO lO = lt OEE GJEOURAEO LOE 
StyleReference="StyleReference"™ 
Wrapping=" {NotSet |Wrap |NoWrap}" 


AutoPostBack=" {True|False}" 
Checked=" {True|False}" 
OnCheckedChanged="EventHandlerMethodName”"™ 
TextAlign=" {Left | Right} " 
Text="LabelText" 

</mobCB:Checkbox> 
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يبين الجدول التالي يبين الخصائص والأحداث التي يدعمها عنصر التحكم هذا: 
الخاصة أوالحدث النمط الوصف 


TruelFalse AutoPostBack‏ تقوم بتعيين أو إعادة القيمة التي تحدد 


فيما إذا كان سيجري إرسال حالة 
عنصر التحكم إلى المخدم عند النقر 
على هذاالعنصر .تكون القيمة 
التلقائية لهذه الخاصة هي عی[ھ۴ 
ويمكن تطبيقها على مستعرضات 
Him1‏ فقط. 
في حال كانت لهذه الخاصة القيمة 
6 نحتاج إلى وجود عنصر 
آخر ليقوم بعملية إرسال النموذج 
إلى المخدم. 
True | False Checked‏ تقوم بتعيين أوإعادة القيمة التي تحدد 
فيما إذا كان عنصر التحكم مختارا 
في الوضع البدائي. 
System. Web.UI.We TextAlign‏ يتم استخدام هذه الخاصة لتحديد 
bControls.TextAlign‏ 

محاذاة النص المرتبط بعتصر 
LeftlRight‏ التحكم. 


String‏ تستخدم هذه الخاصة لتعيين أوإعادة 
قيمة النص المرتبط مع عنصر 
التحكم هذا. 

انحدٽ CheckedChanged‏ طريقة معالج الحدث تعيين اسم طريقة معالج الحدث. يتم 
إطلاق هذا الحدث عند تغيير قيمة 
llخاصة .Checked‏ 


يوضح المثال التالي استخدام عنصر التحكم هذا: 
Register TagPrefix="cc1" Namespace="MobileCheckbox"‏ @%< 
Assembly="MobileCheckbox" $%>‏ 
Page language="c#" Codebehind="default.aspx.cs"‏ @%5< 
Inherits="MSPress.MobWeb. CheckboxEx._ default"‏ 
AutoEventWireup="false" %>‏ 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 
Assembly="System.Web.Mobile" $%>‏ 


<mobile:Form id="Form1" runat="server" title="Facts about Wales"> 
<mobile:Label id="Label3" runat="server" StyleReference="title"> 
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Facts about Wales:</mobile:Label> 
MOO NE Label AEA DeElZL EUNAE < SEVER 
True or False?:</mobile:Label> 
SEE SCRECE ROO MASE ECEODOSI ROMA ES SERVE 


IText="Caplilcal 1s Cardiff" S5</ccl:CheckDOoxK> 
<SEEl ERE CKOOS MA-1 CNEGKOOSZL EUNICE = SCEEVE EL 


rn 


Text="Highest mountain is Snowdon"></cc1l :Checkbox> 
SEE SCRMECEKRBDOS MEAS CRMECEKOOSSS E EURNIE SERVET 


Text="Favorilltêe SBOEL 1S rFUGbyYT=></ cel :Checkbox> 
<mobile:Command i1d="Commandl" runat="server">Next</mobile:Command> 


</mobi le :EOorM> 


<mMOOM le SEOEM TEAL EOEMZLN UNAL LSELVUEL EEE RESULE L> 
moO e Mabel MOE Tae FUNAE= Se VER 
StyleReference="title">Result</mobile:Label> 
<mobile:Label id="result" runat="server">Label</mobile:Label> 
</mobile:Form> 


أما النص البرمجي في الخلفية فهو : 


using System; 
using System.Web.UI.MobileControls; 


namespace MSPress.MobWeb.CheckboxEx 
{ 
public class _default : System.Web.UI.MobileControls.MobilePage 
{ 
protected MobileCheckbox.Checkbox Checkbox1; 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.Form Form2; 
protected MobileCheckbox.Checkbox Checkbox2; 
protected MobileCheckbox.Checkbox Checkbox3; 
protected System.Web.UI.MobileControls.Label result; 
protected System.Web.UI.MobileControls.Form Forml; 


override protected void OnInit (EventArgs e) 
1 

InitializeComponent () ; 

base.OnInit (e); 


1 


private void InitializeComponent () 


{ 


IMLS o COME CUE = 
new System.EventHandler (this.Command1_ Click); 


private void Command1_ Click (object sender, System.EventArgs e) 
{ 

TIME COE ECCE = Û; 

1f (Checkbox1.Checked) correct++; 

1f (Checkbox2.Checked) correct++; 
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1f (Checkbox3.Checked) correct++; 
BeESULE -TexXE > YOM OOE 1 1l COEEECE. NOSEEINI DE 1T COEEECEL, 


NEE IVER OEM < HOEMZ, 


يقدم عنصر التحكم هذا آلية عنصر التحكم ×80)ع٥ط‏ العادية مع إمكانية خاصة للعمل على مستعرضات CHTML «HTML‏ 
.WMLg‏ 


MobileMultiLineInput تم‎ رصڀie‎ 


يقدم هذا العنصر وظيفة إدخال نص متعدد الأسطر كأحد عناصر التحكم المحمولة. تستطيع التطبيقات التي تتطلب كمية كبيرة من الدخل 
النصي كتطبيقات الرسائل والحوار الاستفادة من عنصر التحكم هذا. 


Ë Pockat PC Emulator E 7 &] ã OWG1 - Openwave [E EK] 


Emulator Help File Info Edit Settings Location Help 


® Internet Explorer A 11:15 0 


http: 192. 168.0.35mobilemultiine <| http: 192. 168.0.35mobilemultiine <| 192, 168.0.35fmoabilermultiline ” 


Multiline Text Input Sample 


This chapter is taking longer 
than I thought a5 always! 
- Andy 


Input text is: zeripty = 


Get the text! 


1231]2]3|4 [5|6 [|8 [90| - [=| #| 
1ablq[wje [r [t]¥ [uli [o[p[[ [1] 
carla lalrlalnlrlk zl] 
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إعداد التطبيق: 
كما ذكرنا أنه لا بد لنا من إعداد التطبيق من خلال ضبط الملف ع1گWeb.con‏ 


CONTIG AEIORS 
<system.web> 
<EOMEila Ei On deDUO=LEEUe l> 
<assemblies> 
<add assembly="MLIC" /> 
</assemblies> 
€ COMO LEE LORS 
MOE KE COREE OILS > 
<device name="MMITTextInputHtmlDeviceAdapter" 
inheritsFrom="HtmlDeviceAdapters"> 
<control name="MMIT_Sample.MultilLineInput, MLIC"™ 


adapter="MMIT_Sample.HtmlMultiLineInputAdapter, MLIC"/> 
</device> 
</mobileControls> 
</system.web> 
€ CODE LO UE EAE LORS 


أما الصيغة التي يستخدمها عنصر التحكم هذا فهي التالية: 
Register TagPrefix="mobMLI" Namespace="MMIT_Sample"‏ @%5< 
Assembly="MLIC" %>‏ 


<mobMLI:MultiLineInput 
runat="server" 
OWT O 
Alignment=" {NotSet | Left | Center| Right }" 
Baek CO loOs— I DaACRGE SURES OE 
Font-Bold=" {NotSet|False| True}" 
Font-ltalic=" {NotSet |False | True} " 
Font-Name="fontName" 
Font-Size=" {NotSet |Normal | Small |Large}" 
ForeColor="foregroundColor"™ 


StyleReference="StyleReference"™ 
Wrapping=" {NotSet |Wrap|NoWrap}" 


MaxLength="maxlength" 

Numeric=" {True|False}" 

Password=" {True|False}" 
OnTextChanged="textChangedEventHandler"™ 
Size="textBoxLength" 

Text="Text"™ 

Title="Text" 


Rows =1 {number Of EFOWSIL 
COLS=Y AUIS Oil COLONES > 


< MOLMLTI E MUOIEILINE INU > 
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كما نلاحظ يوفر عنصر التحكم هذا خاصتين أساسيتين: 

الخاصة الوصف 

تحدد هذه الخاصة عدد الصفوف 

التي سيتم إظهارها لهذا العنصر. 
يتم تطبيق هذه الخاصة على 
مستعرضات 1 ۲٢۲1M‏ فقط 


Integer 


تحدد هذه الخاصة عدد الأعمدة التي 


Integer 


سيتم إظهارها لهذا العنصر. 


المثال التالي يوضح استخدام عنصر التحكم هذا: 
Register TagPrefix="cc1" Namespace="MMIT_ Sample" Assembly="MLIC" %>‏ 
Page language="c#" Codebehind="default.aspx.cs"‏ 
Inherits="MSPress.MobWeb.MLICExample._default"‏ 
AutoEventWireup="false" %>‏ 
Register TagPrefix="mobi le"‏ 

Namespace="System.Web.UI.MobileControls" 

Assembly="System.Web.Mobile " %> 


<mobile:Form id="Forml1" runat="server" BackColor="PaleTurquoise"™> 
<mMOOILE:LGbEl TOTTI rina =T"server" 
text="Multiline Text Input Sample"></mobile:Label> 
<cc1:MultilLineInput id="MultilLineInput1" runat="server" 
COILS 291 ROWS OL MalengEN= 1251< CCL SMULE ILI NE INOUE > 
<mobile:Label id="Result" runat="server" 

Text="Input text is: <empty>"></mobile:Label> 
<mobile:Command id="Command1" runat="server" 
Text="Get the text! "></mobile:Command> 
</mobile:Form> 


أما النص البرمجي في الخلفية فهو كالتالي: 
using System;‏ 
USING SYSTEM. Web. UL. MODILECONTEFOLS?,‏ 


namespace MSPress.MobWeb.MLICExample 


{ 
public class _default : System.Web.UI.MobileControls.MobilePage 
{ 


protected MMIT_Sample.MultiLineInput MultiLineInputl; 
protected System.Web.UI.MobileControls.Label Result; 
protected System.Web.UI.MobileControls.Command Command1l ; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


Universal Knowledge Solutions s.a.1 
174 


MobileDynamic[mage pail عنصر‎ 


يحل عنصر التحكم هذا مشكلة تربك المطورين إذ يساعد في استخدام الصور ضمن التطبيق المحمول دون القلق من التجهيزات التي 
ذكرنا مسبقاً بأن أنواع المستعرضات المختلفة تدعم أنماط مختلفة من الملفات مثل ۲61۴[P6‏ ۷8ء ...٥N6‏ إلخ. في هذا 
الإطار يساعد عنصر التحكم #عة١٣آءنصه”مر2ءااه×‏ في أخذ صورة واحدة وتحويلها في زمن التشغيل إلى نمط الصورة الذي 
يدعمه الجهاز الزبون. 


هم المزايا التي يقدمها هذا العنصر التحكم هي: 
تحديد وتصحيح نمط الصورة المناسب وتحويلها بشكل مناسب 
دeم‏ أiمlط‏ اأصgر PNG «WBMP «JPEG «GIF‏ 
تغيير أبعاد الصورة تلقائياً ليناسب حجم شاشة العرض 
يقوم بعملية تخبئة للصورة المولدة بحيث لا يتم إنشاؤها أكثر من مرة 
يدعم تقنية تحويل الصورة الملونة إلى تدرجات الرمادي 
يوفر دعم كامل لمعاينة زمن التصميم ودعم كامل في 0نلuل)؟‏ 21ئ۷ . 
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Dynamiclmage Editor and Preview 


File Information 


Image Source |EMInetpubwvnwarootM abileDynarniclmageE x#arnple™B Browse | 


F7 Image Scaling 


fw 3 Maintain‏ : 5 # ج 100 ا 
cıeen: Width a‏ ج Scale Image‏ ¥ 


mage i EET 


Dither Method [Floya-steinbera >| ¥ | Image Brightness Eian__—_ FE 


إعداد التطبيق: 
لا حاجة إلى إعدادات خاصة ضمن ملف عاگرهء.طeءW‏ لأن عنصر التحكم هذا لا يستخدم أي موائم خاص بالتجهيزات. ولكن يفضل 
أن نحدد مجلد افتراضي خاص لوضع الصور. لذلك يمكن إضافة هذا النص إلى الملف عاگمWeb.c0‏ 
<appSettings>‏ 
<add key="MobileDynamicImagePath"‏ 
value="c:\inetpub\wwwroot\dynimg\" />‏ 


<add key="MobileDynamicImageURL" value="http://Myserver/dynimg/" /> 
</appSettings> 


حيٿ يعرف MobileDynamicImagePath‏ المسار الفيزيائي للمجلد الخاص بالصور وڍعرJۉ MobileDynamicImage URL‏ 


المسار وفق ماهومُعرف في ؟]1. 


تكون صيغة استخدام عنصر التحكم هذا على الشكل: 
Register TagPrefix="mobDI" Namespace="MobileDynamicImage"‏ @%< 
Assembly=" MobileDynamicImage" %>‏ 


<mobDI:MobileDynamicImage 
runat="server" 
1d=" ا‎ 
Alignment=" {NotSet | Left| Centre| Right }" 
BackColor="backgroundColor"™ 
BreakAfter=" {True|False}" 
Font-Bold=" {NotSet|False| True}" 
Font-Italic="{NotSet |False | True}" 
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Font-Name="fontName"™ 
Font-Size=" {NotSet |Normal | Small |Large}" 
ForeColor="foregroundColor™ 
leReference="StyleReference" 

lble=" {True|False}" 


Wrapping=" {NotSet |Wrap | NoWrap}" 


AlternateText="AltText" 
ImageUrl="master ImageSource" 
NavigateUrl="targetURL" 
SoftkeyLabel="softkeyLabel" 


AutoConvert=" {True|False}" 

AutoSizelImage=" {True|False}" 

DynamicImageSource="string" 

ScalePercent=" {0-100}" 

ScaleBasedOn=" {ScreenWidth | ScreenHeight}" 

ImageBrightness= 

"{Auto| Very_Light| Light |Medium | Dark | Very_Dark}" 

ImageDitherMethod=" {ThreshHold|Matrix|Floyd_Steinberg}" 
MaintainAspectRatio=" {True|False}" > 

</mobDI:MobileDynamicImage > 


يوضح الجدول التالي خصائص ieصر‏ llتحكp :MobileDynamic[ mage‏ 

في حال إسناد 1۲٠٥‏ إلى هذه القيمة 
True | False AutoConvert‏ المناسب وإلا سيتصرف عنصر 
التحکم هذا کعنصر تحکم عع2ےص1 
عادي. 

إذا كانت قيمة هذه الخاصة عںآا' 
سيتم تعديل أبعاد الصورة بحسب 
True | False AutoSizeImage‏ الجهاز المستخدم اعتماداً علی 
llخاصة ScaleBasedOn‏ 
و llخاصة .ScalePercent‏ 

تعبر هذه الخاصة عن المسار إلى 
DynamicImageSource‏ الصورة أوعنوان الصورة على 
الوب. 

قيمة في المجال من 0 إلى 100. 
في حال إسناد ٥ن٣‏ إلى قيمة 


Integer ScalePercent‏ الخاصة 2£ Auto S1ze[‏ سیتم 


تغيير أبعاد الصورة باستخدام هذه 
النسبة من الخاصة 
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ScaleBasedOn 
إلى‎ ٣٣۵۴ إذا تم سناد‎ 


TT MobileDynamicImage. 
3 a ANOSENAEE ScaleBasedOnType 
تغيير حجم الصورة اعتمادا على‎ ScaleBasedOn 


ScreenWidthlScreenHeight‏ ا ا 


.ScalePercent 


MobileDynamicImage. 
تحدد درجة الإضاءة للصورة‎ Brightness 

AutolVery_LightlLightl ImageBrightness 
المصدر.‎ MediumlDarklVery_Dark 


MobileDynamicImage. 
DitherMethod 

تحديد تقنية التداخل المستخدمة في 

ThreshHoldlMatrix‏ تحويل الصور. 

IFloyd_Steinberg 


ImageDitherMethod 


إذا تم تعيين هذه الخاصة إلى 
٥6‏ تتم عملية تغيير حجم 
True | False MaintainAspectRatio‏ الصورة مع المحافظة على نسبة 
الطول الأصلي إلى العرض 
الأصلي. 


فيما بلي مثال بسيط يوضح استخدام عنصر التحكم هذا: 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 
Assembly="System.Web.Mobile" %>‏ 
Page language="c#"‏ @%5< 
Inherits="System.Web.UI.MobileControls.MobilePage %>‏ 
Register TagPrefix="cc1" Namespace="MobileDynamicImage”"‏ @%< 
Assembly="MobileDynamicImage" %>‏ 
<mobile:Form id="Form1" runat="server">‏ 
<cc1:DynamicImage id="DynamicImagel" runat="server"‏ 
ImageBrightness="Light" ImageDitherMethod="Floyd_Steinberg"‏ 
DynamicImageSource=‏ 


"C:\Inetpub\wwwroot\MobileDynamicImageExample\BestBuys1.JPG"> 
</cc1:DynamicImage> 
</mobile:Form> 
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E Pocket PE 2002 
File Info Edit Settings Location Help Emulator Help 


Ek) http:##content-tSErM obileD ynamiclmage w ا‎ 


OPENWAVE 
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القسم الحادي عشر : 


الوصول إلى قواعد البيانات باستخدام التطبيقات المحمولة 


الكلمات المفتاحية: 
تطبيق» بيانات» اتصال» النص البرمجي› قاعدة بيانات» علائقية. 


ملخضص: 
تحتاج التطبيقات المحمولة كغيرها من التطبيقات إلى الوصول إلى قواعد البيانات سواء لاستخدام تلك البيانات للقراءة أوالتحرير 
أو التعديل. 
سنناقش في هذه الجلسة الأغراض المستخدمة لتأمين هذا الاتصال وتوافق كل غرض من هذه الأغراض مع سيناريوهات الربط 
المختلفة. 


أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على : 
مفهوم الوصول إلى البيانات في ۸8۲.۸٤1‏ 
ربط البيانات التصريحي 
أُغراض ۸00.N ٤1‏ وطرق استخدامها 
مكونات البيانلات وطريقة استخدامها. 
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الوصول إلى البيانات 


تتعامل أغلب تطبيقات ۸8۴.٤1‏ مع مختلف أشكال البيانات» إذ يمكن ربط عناصر التحكم المحمولة بمصادر البيانات كما هي الحال 
في عناصر التحكم .ObjectListg «Listy «Selection List J‏ 


يمكن أن تكون أغراض اتعامل مaخع‏ lبlilıٽت «System.Data.DataSetgi ArrayListsi Collection‏ 
و .System.Data.DataTable‏ 


تعتبر ۸20.٤1‏ الجيل الأحدث من تقنيات الوصول إلى البيانات التي تم تطويرها من قبل شركة ا۴هوهإء11» ولكن هذه التقنية 
لاتقدم بدیلاً عن النقنية الأقدم المستعملة وهي 4(0 إذ ما يزال بالإمكان استخدام هذا الغرض وإن كان يفتقد الكثير من الميزات»› 
والأداء الذي تقدمه التقنية الجديدة. 


استخدام ربط البيانات التصريحي في ۸5۶۲.۸٤1‏ 


احتوت العديد من الأمثلة التي قمنا باستعراضها في الجلسات الماضيةء تعبيرات خاصة بالبيانات في صفحات نماذج الوب المحمولة تم تضمينها في 


التأشير ة <% ....# %>. 


يعتبر هذا النمط مناسبا عند الرغبة بالوصول إلى عناصر البيانا. كذلك يمكن استخدام هذه الصيغة لتحقيق الأغراض التالية: 
- استدعاء الطرق أوتقييم التعبيرات. 


أمثلة على صيغة ربط البيانات التصريحي: 
TopTitle 5> 2‏ القيمة التي یتم إظهارها هي تلا 
المحددة للخاصة ء]! 1م٥1‏ ضمن 
<mobile:ObjectList‏ یتم إسناد الخاصة My۸۲۲4۷‏ إلى 
id="ObjectList1"‏ کک 1 
runat="server"‏ الخاصة (a5 0u ce‏ للغرض 


.ObjectList LabelField="TeamName 
DataSource = 
<%5# MyArray %> 


حیث تعبر ۲۲۵% M¥yA‏ عن مثل من 


ArrayList yi Collection نوع‎ 
DataTable yi 


(T amStats.PLlayed‏ تتشكل القبمة الظاهرة هنا من د 
"PES?‏ 
TeamStats.Points) $%>‏ + 


يجمع خصائص الصف كاه) 45ء1 


ونص مباشر. 
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String.Formai‏ يكون محتوى الصفحة فى هذه الحالة 
"POS LELORT OFT;‏ : 
TextBox1 . Text .‏ ھوخر ج llتgl String. Format‏ 
PadLeft (2,'0')) %>\‏ 
GetOdds (SelectionList1‏ 85 6 فى هذا المثال هى طريقة 
.Selection.Text) %>‏ ا 
إدراج القيمة المعادة من تلاك الطريقة 


شمن طفحة الوب المحمولة: 


يمكنك استخدام الربط التصريحي في أي مكان ضمن نموذج صفحة الوب المحمول مادام التعبير يعيد غرض صحيح. 
يحتاج ربط البيانات إلى استدعاء الطريقة 4١,81ة)ة(‏ للعناصر المطلوب ربطها. يكفي استدعاء هذه الطريقة التابعة للغرض الممتل 
لصفحة الوب ضمن معالج حدث تحميل الصفحة»ء مما يؤدي لاستدعائها من أجل كل عناصر التحكم المحتواة ضمن الصفحة. 


النص البرمجي التالي يوضح الصيغة الممكن استخدامها: 


protected void Page_Load(Object sender, EventArgs €) 
1 
E MMS. DABAB E, 


قد يسبب استخدام هذه الطريقة أحياناً حدوث خطأ إذا كان التعبير المستخدم للربط يدل على غرض له القيمة 11نم» فعلى سبيل المثال 


يمكن أن يظهر هذا الخطأً عند محاولة ربط قيمة الخاصة ١٥ناءع1ع؟‏ لعنصر تحكم ائ« ه1اءم1م$ قبل أن يقوم المستخدم باختيار 
أية قيمة للخاصة. لذا من الضروري في بعض الأحيان» تأجيل عملية الربط لحين التأكد من إسناد قيم للعناصر المطلوبة: 


يوضح المتال التالي هذه الفكرة: 
Page Inherits="MSPress.MobWeb.DeclDBEx.ExampleWebForm" Language="c#"‏ @%5< 
CodeBehind="DeclarativeDataBinding.aspx.cs" AutoEventWireup="false" %>‏ 
Register TagPrefix="mobile" Namespace="System.Web.UI.MobileControls"™‏ @%5< 
Assembly="System.Web.Mobile" %>‏ 


mo OA E ESED EURAES SEFER MSA LEO 
<mobile:Label id="Label1" runat="server" StyleReference="title"> 
<%# TopTitle %></mobile:Label> 
<mobile:ObjectList id="ObjectListl" runat="server" 
DefaultCommand="aSelection”" 
LabelField="TeamName"™ 
DataSource = <%# MyArray %> > 
<Command Name="aSelection" Text="Show Details"/> 
</mobile:ObjectList> 
</mobile:Form> 


mo SN le E SEM EURA E1 SEEVEE 1 Md LEON 
<mobile:Label id="Label2" runat="server" StyleReference="title"> 
Ou Selected <s OBJOCCELS SEI Select 10n | LTeamName ll € 
</mobile:Label> 
<mobile:TextView id="txvDetail" runat="server"> 
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Nave d 7G CTT OBIECELNSEL Sel eee 1 on E aveA Ll °> a 
BOM RIES E GCF OBDIECCELS SEL Sel OCSE MOM CEHOARESL C> EY 
SF SENN  EORMaAE (EOS EOE O, 


OBJEC ELIS EL Sel eCEI OR | LEOSME TORN | CEASE EZA, ODS 


</mobile:TextView> 
< /mobi le :EForm> 


ويكون الملف العامل في الخلفية هوالتالي: 


using System; 
US IRS SVS eM: CON LEE E ORS 
using System.Web.UI.MobileControls; 


namespace MSPress.MobWeb. DeclDBEx 


{ 


public class ExampleWebForm : MobilePage 


protected System.Web.UI.MobileControls.Form Forml; 

protected System.Web.UI.MobileControls.Form Form2; 

protected System.Web.UI.MobileControls.ObjectList ObjectListl; 
private Jê 1e EAI SE _ û E Û 


protected ArrayList MyArray 
1 


get { return _myArray; } 


OUOSLLE SEE AG HOO ELE 
{ 


Ge 1| FeEUEN SedSON 2003 EEeSULECSL, | 


override protected void OnInit (EventArgs e) 


{ 
InitializeComponent () ; 
Base OMER IE (E) 


DE Iva Ee VOILA MMII lI ZeCOMPORNE ME () 


1 


this.Load += new System.EventHandler (this.Page_Load) ; 
this.ObjectList1. ItemCommand += new 
ObjectListCommandEventHandler (this.OnTeamSelection) ; 


private void Page_Load(Object sender, EventArgs e) 
1 
E (LEM So LEEOSEBACNK ) 
1 
_myArray = new ArrayList (); 
_myArray.Add (new TeamStats ("Dunes",1,38,24,8,6,80)); 
MVAFrFT ay .AdC (new leamstats ( LERNOSONIxX1, 2,90, 240, 10, 8, O, 
myArr av. Ada (mew TeamMSEa ES Eagle S ll, 3,90, 2U, O, O OOD, 
_mvyArray .Add (new Teamstats( lZOdiacl, 4,38,20,8,10, 68J); 


Horm Daa BIRO JE 
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{ 


} 


private void OnTeamSelect ion ( 
Object source, 
ObjectListCommandEventArgs args) 


RORMZ- Dalla REA (N 


ERIS ACEI VEE OEM HOEMZ, 


class TeamStats 
{ 
private String _teamName; 
PE vVaAEe MNE POSH ETON, Plavedy, WON, OFAN, CIOSE, PDOLNES;, 


public TeamStats (String teamName, 
RE MOOSA EO 

int played, 

1 WON, 

dE AW, 

lO 

OLA & 


._ LeamName = teamName; 
EPOSIN ENO < POSTE OM, 
._pPplayed = played; 
._WONn = won; 

EAM = CEA 
10 > 0 
COOIMES  POEMES;, 


String TeamName get ._ LeamName; } } 
TE Position get OSLO J f 
E Played get 1S._played; } 
iE Won get OF 

E Draw get TOFA WR, 

E OSE get NS. lOSE | 

NE Poin get MS OSO ES, 


e 1e e 0 e © 0 


احتوت العديد من الأمثلة التي قمنا باستعراضها في الجلسات الماضيةء تعبيرات خاصة بالبيانات في صفحات نماذج الوب المحمولة تم 
تضمينها في التأشير ة <% ....# %>. 


يعتبر هذا النمط مناسباً عند الرغبة بالوصول إلى عناصر البيانا. كذلك يمكن استخدام هذه الصيغة لتحقيق الأغراض التالية: 
- استدعاء الطرق أوتقييم التعبيرات. 
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ADO.NET مIدختl‎ 


تستخدم جميع الأمثلة التي قدمناها والتي تتعلق بربط البيانات صفوف من النمط 101)ءء]11ه٤‏ مثل ٤ء1‏ ره۸۲. أما إذا كانت البيانات 
التي نريد الوصول إليها مخزنة في قاعدة بيانات فيجب علينا استخدام الصفوف الخاصة ب ۸٥0.N٤1‏ مٿثل صف DataSet‏ 


.DataViewg 


يطرح الوصول إلى البيانات من جهة المخدم تحديات خاصة بسبب عدم تخزين صفحة الوب للحالةء بالإضافة إلى الحاجة المستمرة 
لتحديث البيانات والمترافق مع إنشاء أمثال مختلفة لصفحة الوب بهدف تخديم عدة زبائن. 


توفر ۸90.٤1‏ حلا مناسباً لهذا النمط من المشاكل. إٍذ تقدم ۸00.۴1 الصفوف 04861 وإءلة6 0418۸8 التي تعمل بصورة 


فهم عمل أُغراض :۸00.N ٤1‏ 


:DataSet 

تمتل أغراض 5ه( البيانات الحقيقية التي يتعامل معها التطبيق. ولأن هذه العناصر مستقلة عن مصدر البيانات يمكنك تعديلها 
بصورة مستقلة. على أي حال يمكننا بسهولة إعادة نقل التعديلات إلى البيانات الأساسية. 

تشبه البنية الداخلية لأغراض ع5( بنية قواعد البيانات العلائقيةء فهي تحتوي على جداول» وأعمدةء وعلاقات» وقيود» ومناظير... 


8€ مستقل عن طبقة البيانات يمكننا العمل باستخدام نموذج برمجي موحد بغخض النظر عن مصدر البيانات. 


:DataAdapter 
وهي مسؤولة عن تأهيل أغراض ٥5هه5 بالبيانات.‎ System.Data.IDataAdapter ةqجlوll‎ DataAdap(eث تتبنى صفوف‎ 
تعكس أغراض ١ءامةل 4ة( على أغراض 0486 أية تعديلات تتم على البيانات في قاعدة البيانات.‎ 


:Connection 
MS S؟Qا وتمثل الاتصال الفيزيائي مع مصدر البيانات كمخدم‎ System.Data.1 Db onne تتبنى هذه الأغراض الصف 101ا‎ 
.XML أوملف‎ 


:Command 
وتحتوي أوامر ا5 المستخدمة للوصول إلى مصدر‎ System.Data.105٤0 "21d تعبر عن الصفوف التي تتبنى الواجهة‎ 


البيانات. 


:DataReader 


تلجأ أحياناً إلى استخدام أغراض ١ءلة‏ 2)۸ كبديل عن استخدام ا6؟ةة0 وهي صفوف تتبنى الواجهة 
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System.Data.]DataReader‏ وتوفر وصول فعال للقراءة فقط إلى مصدر البيانات. لا تقدم هذه الأغراض ميزات إجراء التعديلات 
التي تمنحها أغراض ع15( فهي مخصصة للقراءة فقط من مصدر البيانات. 


اختيار مزود البيانات 
تحدد الواجھات ommand »1!DbConnection «[DataReader «[Data Adapter‏ €( كيفية وصول تطبيق إلى قاعدة البيانات. 


مزود البيانات هومجموعة من الصفوف التي تتبنى الواجهات المذكورة وهي خاصة بقاعدة بيانات معينة. 


في إطار العمل.6۲ 1.1 لدينا أربعة خيارات أساسية: 
gjnڌد .SQL Server .NET‏ 
مزود. OLE (8 N٤1‏ يستخدم للاتصال بقواعد البيانات باستخدام الواجهة .0L٤58‏ 
مزود N٤1.‏ ل 1ء0۲ بستخدم للاتصال بقواعد بیانات ع[0c.‏ 
مزود.1 NE‏ الخاص ب 058€. 


SQL Server J«نبتی فعلى سبیل المثال‎ DhataReader و‎ Data Adapters «(Command و‎ «Con ecti01 يتبنى كل مزود أغر اض‎ 
خلl‎ ....SQLDataAdapter «SQLCommand «<SQLConnecti01 فgiص‎ 


لا بد انا إذا لضمان عمل هذا الاتصال مع قواعد البيانات» استيراد فضاء الأسماء المتاسب. ففي حالة ©8 18 مثلاً نبد التصن 
البرمجي بالصيغة: 


using System.Data; 
using System.Data.SqlClient; 


أما في حالة مزود 0_٤58‏ فيصبح النص من الشكل : 
using System.Data;‏ 
using System. Data.OleDb;‏ 


استخدام الغرض ١ءdهء‏ 8 ه٤(‏ للقراءة المخصصة للبيانات 


إذا كان الوصول الذي يتطلبه التطبيق لا يحتاج إلى إجراء تعديلات على البيانات» فإن استخدام الغرض ١ء‏ ل4٠‏ ۸اه( يوفر بديل فعال 
عن استخدام الغرض ع5ه)4(. 


لاستخدام هذا العنصر علينا تأسيس اتصال مع قاعدة البيانات» وتعريف أمر 5Q1‏ لوضع البیانات ضمن غرض ٤٥١۳٣2۸4‏ ثم 
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استخدام الطريقة ۲ع ل2 ۸ع)uءم×E‏ لهذا الغرض . 


تعيد هذه الطريقة غرض ١40۴ء‏ ۸ه)a(‏ يحتوي البيانات التي يمكن استخدامها كمصدر بيانات لعناصر التحكم المختلفة. ولا بد من 
الملاحظة هنا أن هذه العملية لا تتطلب أي غرض من النمط إعامةل۸هtاه0.‏ 


فيما يلي مثال بسيط يستخدم الغرض ١عل4ء۸ه)ه(‏ لتزويد عنصر تحكم ء11 بالبيانات من قاعدة بيانات اS M5‏ هذا: 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 

Assembly="System.Web.Mobile" %> 
<%5@ Page language="c#" Codebehind="DataReaderExample.aspx.cs" 
Inherits="MSPress.MobWeb.DataRdrEx.DataReaderMobi leWebForm" %> 


<mobile:Form id="Form1" runat="server" Paginate="True"> 
<mobile:List id="List1l" runat="server"></mobile:List> 
</mobile:Form> 


ويكون النص البرمجي في الخلفية : 
using System;‏ 

using System.Data; 

using System.Data.SqlClient; 

USING System.Web.UI. MobileControls; 


namespace MSPress.MobWeb.DataRdrEx 
{ 
/// <summary> 
/// Use the DataReader for efficient read-only access to data. 
f11 <f SUM 
public class DataReaderMobi leWebForm 
System.Web.UI.MobileControls.MobilePage 


{ 
protected System.Web.UI.MobileControls.List Listl; 
protected System.Web.UI.MobileControls.Form Forml; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


private void InitializeComponent () 
1 
this.Load += new System.EventHandler (this.Page_Load); 


private void Page_Load(object sender, System.EventArgs e) 
1 
// Use the DataReader to fetch a read-only dataset. 
Sle Lae) SLECOMAECELONSELLNG = HSE wer (LOCAL) NECDET 
"database=pubs; Trusted_Connection=yes"; 
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SqlConnection myConnection = 


new SqlConnection (strConnectionString) ; 
SqlCommand myCommand = 


new SqlCommand ("select * from Authors", myConnection) ; 


myConnection. Open () ; 


SqlDataReader dr = myCommand. ExecuteReader () ; 


TIS E1l Dat aSOUEEe < GE, 
List1.DataTextEField="au_lname"™; 
J SIE J, DEE aE 1O (J f 


myConnection.Close(); 


أُما خرج هذا البرنامج فيكون على الشكل : 


استخدام الغرض 5ه( في عملية الربط بالبيانات 


في الكثير من التطبيقات يقدم الغرض ١ء44ء‏ ۸ة( جميع الوظائف المطلوبة ولكن يصبح استخدام هذا الغرض غير كافي في 
التطبيقات التي تستلزم مناقلات طويلة أوعمليات تحديث على البيانات ضمن قاعدة البيانات. 
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يقدم الغرض 1ء45( العديد من الفوائد أهمها احتواؤه على معلومات حول القيود المُعرّفة ضمن قاعدة البيانات. لذلك يمكنك إجراء 
عمليات التعديل على البيانات مع إمكانية التنبه إلى أي تجاوز لأحد القيود عند تحديث البيانات ضمن غرض 486( قبل تعديلها 
فعلياً ضمن قاعدة البيانات» مما يؤدي لضمان انسجام التعديلات مع القيود المعرفة في قاعدة البيانات عند تطبيق التحديثات على القاعدة. 


تشبه عملية الوصول إلى قاعدة البيانات لتأهيل غرض 0861 العملية التي استخدمناها مع الغرض ١206ء‏ ۸ه1ه(. إذ نقوم بتعريف 


أمر ا لجلب البيانات من قاعدة البيانات باستخدام غرض ١ءاAdap Data‏ بدلا عن غرض .٤٥C0 ٣۸1۳۱214‏ 


يوضح المثال التالي كيفية استخدام الغرض 45601( لتأهيل عنصر التحكم 1اءاcعjز0b:‏ 

// Use the DataAdapter to fill a dataset. 
SEEING STEConNNECEIORSLT ING 2 

"server= (local) \\NetSDK;database=pubs; Trusted_Connection=yes"; 
SqlConnecEion myConnectioln = 
new SqlConnection (strConnectionString) ; 
SqlDataAdapter myCommand = 

new SqlDataAdapter ("select * from Authors", myConnection) ; 


DataSet ds = new DataSet (); 

TCEIEREl HINL (CAS, HALEMOE SY) o 

ObjectList1.DataSource = ds.Tables["Authors"] .DefaultView; 
ObjectList1.LabelField = "au_lname"; 
ObjectList1.AutoGenerateFields = true; 

OS J SECE LI SE 1 . DAE AE E (J 2 


نلاحظ بأن الغرض (45٥1‏ يحتوي أغراض كءء1ط1214ه0 التي تحتوي بدورها أغراض 0W‏ 02)4۸ و۸ unاە)0ata.‏ تقدم ھذہ 


الصفوف معا مجال واسع من الوظائف للتعامل مع البيانات. 


إنشاء تطبيق وب محمول يقوم بتحديث البيانات 


في حال كان التطبيق المراد إنشاؤه يحتاج إلى إجراء تعديلات على معطيات قاعدة البيانات» تتلخص الطريقة الأفضل في إجراء 
التعديلات على غرض (45٥1‏ وتخزينها ثم تطبيق هذه التعديلات على قاعدة البيانات باستخدام الغرض ١ءامa‏ ل۸ هa)4(.‏ 


أما إذا قام المستخدم بإجراء تعديلات من شأنها أن تؤثر على سجل وحيد» فنستطيع تبني الطريقة الواردة في المثال التالي: 
Page language="c#" Codebehind="DataUpdateExample.aspx.cs"‏ @%< 
Inherits="MSPress.MobWeb.DataUpdateEx.DataUpdateMobileWebForm" %>‏ 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 
Assembly="System.Web.Mobile" %>‏ 


<mobile:Form id="Forml1" runat="server" Paginate="True"> 
<mobile:ObjectList id="ObjectList1" runat="server"> 
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<Command Name="EditCommand" Text="Edit Details"/> 
< /mMoODIlE:OD I ECLLISE > 
</mobile:Form> 


MOONEE EOEM IGA EOEMZ EUNICE SOV 

<mobile:Label id="Label1" runat="server" 
text="Edit Author Details" StyleReference="title"/> 
MOA Ne Label LUNE =I SeRVEeE LY 

Author ID: <%# ObjectListl1.Selection ["au_id"] %> 
</mobile:Label> 
First Name: 
<mobile:TextBox id="TextBox1l" runat="server" MaxLength="20" 
Text='<%# ObjectListl1.Selectionl["au_ fname"]%=' /> 
Last Name: 
<mobile:TextBox id="TextBox2" runat="server" MaxLength="40" 
Text='<%# ObjectList1.Selection ["au_lname"] %>' /> 
<mobile:Label id=Label3 runat="server" 
StyleReference="error" Visible="false"/> 
MOO le COMMANGS MO lCommManOl. rUNAE< Se VEE EXE < EL 
CommandName="Save" /> 

SMO A Ne SCOMMANES AOI COMMAR OZ EUNAE ZL SCE VER lex E < CAEN 

CommandName="Cancel" /> 

</mobile:Form> 


ويكون النص البرمجي في الخلفية: 


using System; 

using System.Data; 

using System.Data.SqlClient; 

USiNG SySTEemMm. Web. UL. Mobi leControls; 
using System.Web.UI.WebControls; 


namespace MSPress.MobWeb. DataUpdateEx 
{ 
/// <summary> 
/// Use the DataReader to fetch the data. 
/// </summary> 
public class DataUpdateMobi leWebForm 
System.Web.UI.MobileControls.MobilePage 


SqlConnection myConnection; 


ا 
1 


E CSMELEO LS: OBESE SE OBJEC ELA SEL; 
lECOMEEO LS. EOEM ONAL 

u ا‎ BHOEMZ, 
leControls.Label Label3; 
leControls.Command Command1l ; 

. Command Command2; 
leControls. TextBox TextBox1l; 
leControls. TextBox TextBox2; 


protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 
protected System.Web. 


TF € E FG € 
aa 


ا 
| 


override protected void OnInit (EventArgs e) 


1 
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InitializeComponent () ; 
base.OnInit (e); 


1 


private void InitializeComponent () 


{ 


this.Load += new System.EventHandler (this.Page_Load); 

this.ObjectlList1.ItemCommand += new 

ObjectListCommandEventHandler (this.OnEditCommand) ; 

this.Command1. ItemCommand += new 

CommandEventHandler (this.CancelConfirmEdit) ; 

this.Command2. ItemCommand += new 
CommandEventHandler (this.CancelConfirmEdit) ; 


private void Page_Load(object sender, System.EventArgs e) 
{ 
// Use the DataReader to fetch a read-only data set. 
SEE LAG SCECOMNECELONSELLNO = WEE EE = (LOCAL) \MNECSDKFE F 
"database=pubs; Trusted_Connection=yes"; 
myConnection = new SqlConnection (strConnectionString) ; 


E KITS EOSEBAEE) BIME SE, 
ا‎ 


SNE eG EE 
1 
SqlCommand myCommand = 
new SqlCommand ("select * from Authors", myConnection) ; 
myConnection. Open (); 
SqlDataReader dr = myCommand. ExecuteReader () ; 


ObjectList1.DataSource = dr; 
ObjectlList1.LabelField = "au_lname"; 
ObjectlList1.AutoGenerateFields = true; 
OD jee ELA SEL. DataBineE ); 


2 


The field names of au_id, au_lname, and au_fname 
do not provide good titles, so change them in the 
AlIEieIAS COl leECE1 ON. 


l1Fields [ObjectList1.ALll1lFiel IRE ExXOE (Tau OD | 
El = AVEO LDP 


l1Fields [ObjectList1.ALll1lFiel . IndexOf ("auüu_fname") | 
ELS = TI ESE Nee; 


l1Fields [ObjectList1.ALIFİ . IndexOf ("au_lname") |] 
TE leê > WSE Namel;, 


<summary> 
Called when the user clicks the 'Edit Details' link 
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/// </summary> 

protected void OnEditCommand ( 
Object source, 
ObjectlListCommandEventArgs args) 


// DataBind the form to insert the selected item details. 
HORM 2Z.DaE ABR, 

ENA SL ACEI VCE OEM < BOE, 

Label3.Visible = false; 
Command 1ı VI SAblêE 2 EEUe;, 
Command2.Visible = true; 
COMMEAGZ TEE = CAMEL 


} 


/// <summary> 
//7 Called when a user Clicks on either 'Save' ofr Cancel! 
BU EON 


/// on Edıt SECEeena 
/// </summary> 
private void CancelConfirmEdit (Object sender, CommandEventArgs 


{ 
Lf (e.CommandName == "Save") { 
SaveChanges(); 
ِ 
else 
1 
// @o Baek to the LASSE VION: 
ERAS Ae ve EON < FOE, 
ObjectList1.ViewMode = ObjectListViewMode.List; 


} 


EMC EE (J f 
1 


private void SaveChanges () 


{ 
String updateCmd = "UPDATE Authors SET au_lname = @LName, " 


"au_ fname = @FName where au_id = @Id"; 


SqlCommand myCommand = new SqlCommand (updateCmd, 
myConnection) ; 


myCommand. Parameters. Add ( 

New SGOIPoOTaNELCO (ETE, SOIL DE aT Cat, UI, 
myCommand. Parameters. Add ( 

new SqlParameter ("GLName", SqlDbType.NVarChar, 40)); 
myCommand. Parameters. Add ( 

new SqlParameter ("GEName", SqlDbType.NVarChar, 20)); 
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myCommand. Parameters ["G@GId"]|.Value = 
ObjectList1.Selection ["au_id"]; 

myCommand. Parameters ["@GLName"] .Value = TextBox2.Text; 

myCommand. Parameters ["G@GFName"] .Value = TextBoxl. Text; 


myCommand.Connection. Open (); 


EE 
{ 
myCommand. ExecuteNonQuery () ; 
Label3.Text = "Record Updated"; 
} 
CA BEN (SOL EXCE BIE HOR) 
{ 
Label3.Text = "ERROR: Could not update record"; 
} 


myCommand. CONNECEIONn. Close) F 


abel .VISIble > EKU; 
Command1.Visible = false; 
Command2.Visible = true; 
Command Mex Back. 


يستخدم التطبيق في هذا المثال عنصر التحكم ء1اءءزطا0 لإظهار البيانات المخزنة ضمن الجدول ك0۲ط)اه في قاعدة البيانات 
.Pubs‏ 


يعرف النص البرمجي» العنصر <ل >٥٣ ٣21‏ ضمن ملف ×طءه بحيث يساعد المستخدم في تحرير التفاصيل. فعند الضغط على 
هذا العنصر یظھر النموذج ۴٥۲٣١2‏ مبيتا قيم الحقول الحالية باستخدام عناصر تحكم متل 1١×)80×‏ تساعد في عملية التحرير. 


يبين الشكل التالي شكل الواجهة عند تنفيذ هذا البرنامج : 
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Last Name O'Leary 


Auıthor ID 2567-41-2394 
Last Name O'Leary 
First Name Michael 
phone 408 286-2428 
address Zê leveland Av. #14 
city Saf Jase 
state ےا‎ 
zip 35128 
contrarlt Tre 
[ Edit Details | Back ] 


view Tools ۉ‎ EY oF (&] |> Yiew Tools ۉ+‎ |} Î E 


Edit Auıthor Details Edit Auıthor GCetails 
Author ID: 267-41-2394 Author ID: 267-41-22324 
First Mame: First Mame: 


Last Mame: Last Mame: 


Record Wpdatedl 


elel aS 


r [t[¥|u[i [o|p[T[1| 


Snirtl z2]x«[cj¥[b[n]m]. |. 14| 
ك ا‎ 
کے انا بعتب‎ IE Yiew Tools 4# AE E> 


يُستخدم النموذج المستخدم لتحرير الاسم والشهرةء زرين: يكون الأول مخصص لتثبيت التعديلات ويكون الثاني مخصص لتجاوزها. 
وتجري عملية معالجة الضغط على هذين الزرين باستخدام طريقة واحدة لمعالج الحدث 012۸4 0n])em٣‏ هي 
.CancelConfirmEdit‏ 


يتوضع النص البرمجي المسؤول عن عملية التعديل ضمن الطريفة ومعمهط٣۷ه؟.‏ نلاحظ أننا قمنا هنا أيضاً باستخدام معاملات 


)@( ا المسبوقة بإشارة‎ 
String updateCmd = "UPDATE Authors SET au_lname = @LName, " + 
"au_ fname = @GFName where au_id = @Id"; 
SqlCommand myCommand = new SqlCommand (updateCmd, myConnection) ; 


يقوم النص البرمجي ضا بإضافة أغراض معاملات SQ‏ وهي Q۴2‏ إلى غرض 14 $1٤01‏ مع تحديد نمط 
البيانات لكل منها وذلك بالتعبير : 


myCommand. Parameters.Add (new SqlParameter ("@GId", SqlDbType.NVarChar, 
1JJ, 


Universal Knowledge Solutions s.a.1 
194 


يحدد النص البرمجي بعدها القيم المطلوب استخدامها لهذه المعاملات وذلك بالصيغة : 
myCommand. Parameters ["@GLName"] .Value = txtLName. Text;‏ 


يمكننا بعد ذلك تتفيذ الاستعلام بطريقتين: الأولى هي باستخدام الطريقة مااءم×8 وفي هذه الحالة تجري عملية إعادة غرض 
t€‏ والثانية هي باستخدام الطريقة N0 Quy‏ عءاuءم×8‏ وفي هذه الحالة يجري تتفيذ الأمر دون إعادة غرض 52)5٤‏ 


وهذا ما نفذناه باستخدام الصيغة: 


myCommand. ExecuteNonQuery () ;‏ 
نستطيع تطبيق عمليات الحذف والإدراج بطريقة مشابهة وذلك بتغيير نص استعلام اSQ.‏ 
بناء مكونات البيانات باستخدام بيئة Visual Studio‏ 
تقدم بيئة 0نلدا؟ 1٠ء۷1‏ العديد من الأدوات التي تساعد المطور للعمل على البيانات. 


يساعد مصمم إ#١عوم‏ ام5هtة(‏ في التعامل مع أغراض قواعد البيانات باستخدام مخطط قاعدة البيانات» حيث يمكن إنشاء قاعدة 
بيانات تحتوي جداول» وصفوف» وأعمدةء ومفاتيح» وأدلةء وعلاقات» وقيود. يجري تقديم كل ذلك بطريقة مرئية تفاعلية. 


سنتعرف في ما تبقى من هذه الجلسة على أداتين مهمتين أيضاً .Component Designer sy Server Explorer laa‏ 


استخدام مستكشف nllخدم :Server Explorer‏ 
تسمح هذه الأداة بالوصول والتجول ضمن مصادر البيانات المختلفة المتوفرة لتطبيقك. يمكنك الوصول إلى هذه الأداة باستخدام الخيار 


. View من القائمة‎ Server Explorer 


يمكنك باستخدام هذه الأداة: 
تأسيس اتصال مع مخدم قاعدة بيانات ©$ وقواعد البيانات الأخرى. 
الاتصال مع مخدمات 5Q1‏ لإظهار البيانات التي تحتويها. 
الاتصال بالأنظمة على شبكتك وإظهار الخدمات التي تقدمها بما فيها قواعد البيانات» وسجلات الأحداث» وأرتال الرسائلء 
وعددات الأداء. 


إظهار المعلومات المتعلقة بخدمات الوب المتوفرة ومخطط الطرق التي توفرها. 


توضح اللقطة التالية عمل هذه الأداة: 
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Solution Explorer - DataComponentExample # $; 
4 Solution 'DataComponentExample' (2 projects) 
= E AutharsDataComponent 
2 (ã] References 
# AssemblyInfo,cs 
5] Authscomponent, cs 
=| AuthsDataSet. xsd 
ataComponentExample 
(&] References 
# AssermblyInfo,cs 
El DatazomponentExample, aspx 
]چ‎ slobal,asax 
Web, config 


2 


Dynamic Help 
© 3 
ıl Help 


Table Designer 


3 j thscomponent,cs [Design] | AuthsZomponent,cs | {Ap x 


|ã%5avechangesû r 


ist View 
entryForm; 
= DObjeCtListVieuMode . List; 


From the Session  oMjeCt 

hsDPataSet] Session["KyDataSet"] 

e changes 

w rovwToChange = ds.authorsz.FindEyau_id {ob lAut] 
txtFName . Text; 

E. Text; 


pass it the Dataset s0 it can update the data} 
aths (d3) } 


E 0 Data Connections 
E f] servers 


H Crystal Services 
| Event Logs 
E} Message QUEUES 
El Performance Counters 
e Services 
E E SQL Servers 
1. Fg TESTMCINETSDK 
TH. Ê GrocerToto 
& master 
Ë model 
@& msdb 
& Northwind 
& Portal 
E pubs 
ÎBğ Database Diagrams 
Ê Tables 


4210|32 #an4aç 1 E" 


E aud 

E] au_hame 
E] au_fname 
phone 

| address 


Database Connections and Database Reference 
EventLoa Programming Architecture 
Introduction ta the EventLog Component 
Lreating EventLog Component Instances 

Fils System and Scheduling Components 

city konfiguring EventLaq Component Instances 

=] state Active Directory Components 

zip Serwer Explorer 

rantrart konnecting ta Data Sources with Serwer Explore 
tenûr Intraduction to Server Explorer 


Employee ۴ | 


2 Properties a Dynamic Help 


| fyString property | 3 Search Results for system ,web configuration | 


بناء مكونات البيانات باستخدام بيئة Sudo‏ اVisua‏ 


يمكن للتطبيقات البسيطة الوصول إلى قواعد البيانات مباشرة بالشكل الذي قمنا بتوضيحه في الجزء السابق. 


على أي حال» من المفيد عندما نتكلم عن تطبيقات أكثر تعقيداً استخدام نموذج متعدد الطبقات (116۲-ه) حيث يتم فصل الطبقات 
التي تقوم بمعالجة واجهة المستخدم عن تلك التي تهتم بمعالجة البيانات. بحيث يتم خلق مكونات مهمتها التعامل مع البيانات بالنيابة 
عن تللك الطبقات. 


في بيئة متعددة الطبقات تقوم صفوف واجهة المستخدم باستدعاء مكونات البيانات التي تقوم بتطبيق منطق العمل. وتستدعي 
مكونات الطبقة الوسيطة مكونات أخرى مهمتها استعادة البيانات وتحديثها. 


في مثل هذه البيئةء تعد أغراض ٥8اه‏ مثالية لتأمين عملية نقل البيانات بين المكونات كونها منفصلة تماماً عن قاعدة البيانات 
مع قدرتها كما ذكرنا على الاحتفاظ بمعلومات عن العلاقات والقيودء تقوم بتطبيقها عند تعديل البيانات. 


توفر بيئة Visua1 St»d10.N٤1‏ أداة لتصميم المكونات مرافقة لأداة ۲٤]0آام×E S۷۲‏ مما يجعل من عملية بناء مكونات 
بيانات عملية سهلة. 
لتوضيح عمل هذه الأدوات سنقوم بتعديل المثال الوارد في الشريحة السابقة باستخدام مكونات البيانات: 
سنقوم في البداية بإنشاء مشروع جديد من نمط مكتبة صفوف ٥#‏ ونسميه .AuthorsD ata001٤1٤‏ سیتم بھذە 
العملية إنشاء مشروع يتم تفسيره إلى لغة التجميع وهويحتوي بصورة داخلية صف بالاسم ٣1441.٥8‏ سنقوم بحذفه لأننا 
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سنقوم بالنقر بالزر الأيمن على ملف المشروع واختیار خیار ۸d1‏ من قائمة †×ع†con‏ ڑ¦۾ iختlر .Add Component‏ 


.AuthsComponent.cs ک¡ذkÛ| دخل اسم‎ pû Component Class رlaتخi‎ NewItem öذفli في‎ 


يقوم عندها 10لن†؟ V1sua1‏ بإضافة sع‏ .)0081م 0m‏ ءطAut‏ إلى مشروعنا ويقوم بفتحه ضمن وضعية التصميم. 

نقوم الآن بالنقر على مستكشف المخدم لمحاولة الوصول إلى الجدول كإ0طااة ضمن قاعدة البيانات sطام.‏ 

نقوم بعدها بعملية جر الجدول 0۲١‏ )نه إلى مساحة التصمیم بحيث يتم لقائياً إنشاء غرض 5SQ1[€011۴٥٤10١‏ وغرض 
t4۲‏ ويتم تلقائيا توليد النص البرمجي المرتبط بتلك الأغراض المضافة متضمناً عبارة الاتصال 
الصحيحة مع غرض 501٤00٣314‏ لإجراء علميات الاختيار» والإضافةء والتعديل والحذف. 


-M-S8 HA # BEB @|¬-c*-E8-B rota EE oblAuthors BER R-O 
Ê | A|T o & FE FE FI BE |ooe ¥e E RF | $ $ $ | mM El | a - 
BÎ |pls.aspx.cs AuthsComponent.cs [Design] | AuthsComponent.cs | Solution Explorer - AutharsDatacomponent _# * 
| 8 HE BEE 
|! Data Cannectiorıs 4 Solution DataCompanentExample" (2 projects] 
|, Servers Ê E AuthorsDatacomponent 
E] testmc | E- ê] References 
Crystal Services ا‎ 3 AssemblyInfo,cs 
0 a : ا‎ 2 
ti] Event Logs Ê sqlConnertion1 fl sqDataAdapter1 ا‎ &) huthrscomponent cs 
| AuthsDataset.xsd 
1- [J Performance Counters EF e DataComponentExample 
& a Services H- Û] References 
E f SQL Servers û AssemblyInfo.cs 
- @y TESTMCINETSDK E] DataComponentExample.aspx 
I && GrocerToGo Global.asax: 
f maskter | Web.config 
1 & model 


3210 |3 #125 


- & msdb 
BA. @& Northwind 
f& Portal 
fy pubs 
& E Diag Dynamic Help 
E Tables 71 4 
E ا‎ 
O discounts a Help 
£ employee Table Designer 
jobs Database Connections and Database Reference 
ِ pub _info Eventlog Programming Architecture 
+ publishers Introduction ta the EventLog Component 
8. roysched Creating EventLoqg Component Instances 
I salts 1 1 
3 stores Configuring EventLoq Component Instances 
4]. titleauthar Active Directory Components 


يقوم المكون الذي قمنا بإنشاءه بالاتصال مع الصفوف الأخرى عن طريق إرسال واستقبال أغراض اء؟هة5. 


يساعد مصمم المكونات في توليد غرض 04)5٥‏ خاص بالجدول الذي قمنا باختياره. نختار القائمة 2a‏ ثم lلخيlر Generate‏ 
8 وفي هذه النافذة يجب علينا النقر على سع" ثم ادخال اسم 4)5٤‏ ءط)Au‏ كما هوموضح في الشكل التالي: 
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Generate Dataset 


menerate a dataset that includes the specified tables, 


Lhaose a dataset: 


f Exsting | o] 
fF New: a uthsData5et 


Lhaase which Lables} to add to the dataset: 


| authors tsqlCataAdapter 1) 


¥ Add this dataset to the designer, 


عند النقر على &0» يجري إنشاء ملف ×١]‏ خاص بغرض (4)5٥‏ باسم 4ء×.1٥4)45(ءط)Au‏ وتجري إضافته إلى المشروع 
ثم يجري إنشاء مثيل من هذا الغرض الجديد باسم 1٥2)5(ءط)اه‏ وإضافته إلى شاشة التصميم. 


يحتوي مكون البيانات المنشأً على جميع الإمكانيات اللازمة للتعامل مع البيانات ضمن الجدول ؟0۲طالاج. 


لايقدم النص البرمجي الذي تم توليده لهذا الصف أي شيء لتطبيقنا ما لم تجر إضافة طريقة لتأهيل غرض (a56‏ وتجعله متوفرا 
للعالم الخارجي. إذا يجب إضافة الخاصة العامة التالية إلى الصف الذي يقوم بتغذية عناصر الصف 1٥445ءطا‏ ناه كما يلي: 
<summary>‏ /// 
Returns a dataset of all authors in the authors table of the pubs‏ /// 
database‏ 
f11 <ASUOMEEVE‏ 
public AuthsDataSet AllAuthors‏ 
1 
GEE‏ 
1 
Update class member dataset.‏ // 
EMI GS. SGIDAESAAAAPECEEI ELI CEMI S AUER SDAEASEE, AMEROE SL);‏ 
Ee UED ENIS AUEMS DAE ASE E‏ 


تقوم الطريقة ۴111 الخاصة ب اعام ةل 8410a) 4A‏ بفتح اتصال بصورة أو توماتيكية مع قاعدة البيانات وقراءة البيانات إلى غرض 
tet‏ ثم إغلاق الاتصال. 
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گك بی لی ا لرن ت لطر ا رکون اغد ات که آي و عى لااك نحل اس افرمجي لذي ق 
مصمم المكونات بتوليده من عملية التحديث غاية في السهولة. 


قام مصمم المکونات بإعداد غرض SQLDataAdapter‏ مع غرض 541٥۳0١11414‏ المناسب لعملية الإدراج» الحذف... 

عند استدعاء طريقة عاهل مل الخاصة بغرض ١ع)م2‏ 50134 يتم تمرير غرض 561( إلى هذا الغرض محتو 1 التعديلات 
التي تمت. 

يقوم المحرك بعدها بتطبيق هذه التعديلات لكل صف من الصفوف ضمن غرض 41561( الذي تمت عليه عملية الإضافة أوالحذف 
أو التحديث. 


يكون النص البرمجي الواجب إضافته لتبني طريقة عامة لتحديث قاعدة البيانات كما يلي: 


استخدام مكون البيانات ضمن تطبيق الوب 


عند إزالة النص البرمجي الخاص بمعالجة البيانات من صف التطبيق الرئيسي يصبح أكثر ترتيباً مما يساعد في التركيز على تقديم 
واجهة أكثر مناسبة للمستخدم. 


سنقوم بإعادة صياغة بعض الأجزاء من المثال الذي رأيناه في تحديث قواعد البيانات في تطبيقات الوب المحمولة لنطبق عملية استخدام 
مكونات البيانات. 
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لاستخدام مكون البيانات يجب إضافة مرجع إلى هذا المكون ضمن المشروع وذلك من خلال liفذö :Add Reference‏ 


Add Reference 1 


NET |com | Projects | 


× 
Browse... | 
component Namê |veson  |Ph _ *خ|‎ 


ûrressibiliky dll 1.0,2411.0 EN WIMATIMicrosaft,NETIFra,.. select 
adodb لالا‎ Ef Program Files\Microsoft... 
LRAYsPackageLib 1.0.0.0 E Program Files{Microsoft Yis,,; 
Lrystalbecisions, CrystalRepo,,, 3,1,0,0 E Program Files\Microsoft Yis,,. 
Lrystalbecisions, Reportsource 3,1,0,0 Ef Program Files\Microsoft Yis,,., 
trystalGecisions, Shared 4.1.0.0 E Program Files\Microsoft Wis... 
Lrystalpecisions, Web 4,1,00 Ef Program Files{Microsoft Wis, ; 
Lrystalpecisions, Windows, Fo,,, 3,1,0,0 E Program Files{Microsoft Wis, ; 
LrystalEnterpriseLib 1.0.0.0 E Program Files\Microsoft Yis,,, 
LrystallnfoStoreLib 1.0.0.0 E: Program Files\Microsoft Yis,,, 
LrystalkKeyZodeLib 1.0.0.0 E Program Files\Microsoft Yis,,. 
TrwstalPlninMnrl ih 1.0.01.0 FPrnnrarm Files Mirronsnft Wis... 


Selected Zamponents: 


Remove | 


AutharsDataLomponent , dll E Dacuments and SektingsAd... 


Ok ل‎ angel | Help | 


يتوجب علينا بعدها إضافة تصريح عن هذا المكون في بداية النص البرمجي في الخلفية وذلك بالصيغة: 
using MSPress.Mob.Web.AuthorsDataComponent;‏ 


تتلخص المرحلة التالية في إنشاء مكون البيانات كعنصر خاص ضمن الصف وذلك بالصيغة: 
private AuthsComponent myDataComp;‏ 


private void Page_Load(object sender, System.EventArgs e) 
{ 

// Create the data component each time the application 

// EEEUENS EO Me SERVER, 

myDataComp = new AuthsComponent () ; 


iE (lISEOSEBACR) 
BUREN SE OF 


ويكون النص البرمجي للطريقة †ئ81"U1‏ كما يلي: 
[public void BindList ()‏ 


{ 
// Use the DataComponent to fetch a dataset. 
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AuthsDataSet ds = myDataComp.ALLlAuthors; 


ObjectListl1l.DataSource = ds.Tables ["authors"] .DefaultView; 
ObjectListl.LabelField = "au_l1lname”"; 
ObjectList1.AutoGenerateFields = true; 

OO JECE LI. SE 1 «DEAE AE AC (J 


// The field names of au_id, au_lname, and au_fname do not provi 
// OOood EIEleS, SO Change Enhem AM the AIEEE NAS COlleECEION. 
ObjectList1.ALllFields [ObjectList1.ALllFields. IndexOf ("au_id") ] .Ti 

= "Author ID"; 


= Ng EE MEMS 


Tas Mame l;‏ کک 


TOE iE DG oN TE Md TG CECE IO TTI SO CGC 
// it can persist across MüUlEiple postbacks. 
Session ["MyDataSet"] = ds; 


تصبح الطريقة sعع«ة‏ 1٣۳ء54۷‏ بعد إعادة كتابتها لاستخدام مكون البيانات على الشكل: 


ObjectList1.AllFields [ObjectList1.ALllFiel .TRIeExXOE (aU Enamel) ll TEL 


ObjectList1.AllFields [ObjectList1.ALllFiel TRIO (aU name) ll UIE 


private void SaveChanges () 


// Retrieve the dataset from the Session object. 
AuthsDataSet ds = (AuthsDataSet) Session ["MyDataSet"]; 
// Find the row and make changes. 
AuthsDataSet.authorsRow rowToChange = 

AS. AUENOES  EINOBVAU 1O (OC jEeC ELSE 1L Selec ENON I aU ALI), 
rowToChange.au_fname = TextBoxl. Text; 
rowToChange.au_lname = TextBox2.Text; 


// Call the UpdateAuths method of data component. 

// Pass it the dataset so that it can update the database. 
LE (myDataComp.UpdateAuths (ds) ) 

Label3.Text = "Record Updated"; 


lse 
Label3. Text = "ERROR: Could not update record"; 


Label3.Visible true; 
Command1.Visibl مج ا2ا ک‎ 
Command2.Visible = true; 
Command Z2 Ex E - HACE; 


{ 


عند إزالة النص البرمجي الخاص بمعالجة البيانات من صف التطبيق الرئيسي يصبح أكثر ترتيباً مما يساعد في التركيز على تقديم 
واجهة أكثر مناسبة للمستخدم. 
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سنقوم باعادة صياغة بعض الأجزاء من المتال الذي رأیناه في تحديث قواعد البيانات في تطبيقات الوب المحمولة لنطبق عملية استخدام 
مكونات البيانات. 


لاستخدام مكون البيانات يجب إضافة مرجع إلى هذا المكون ضمن المشروع وذلك من خلال liفنö :Add Reference‏ 
تزود بيئة Visua1 Stud10.NE1‏ مصمم مکونات مرافق لأداۃ ۲٤]oاE×xp Se۷e١‏ مما یجعل من عملیة بناء مکونات بیانات 
- لتوضيح عمل هذه الأدوات سنقوم بتعديل المثال الوارد في الشريحة السابقة باستخدام مكونات البيانات عوضاً عن استخدام 
منطق معالج البيانات المبيت. 
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الموضوع الأول: إدارة الحالة 


الكلمات المفتاحية: 
تطبيق» حالة» جلسة» كعكة» غرض 


ملخض : 


لما کان بروتوکول ۳۲۲۴ هو بروتوكول لا يحافظ على الحالة بين طلبات ۳۲۲۴ المتتاليةء فلا بد من إيجاد طريقة لإدارة الحالة 


وهذا ما سنقوم بتغطيته في هذه الجلسة. 


أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على: 
مق لكا ور ا 
ه٠‏ حالة الجلسة وطرق حفظها. 
ه٠‏ حالة التطبيق. 
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إدارة الحالة 


سنحتاج غالبا عند بناء تطبيقات الوب الديناميكية إلى آلية لتخزين المعلومات بين طلبات الزبون. لسوء الحظ لايحفظ البروتوكول 
1P‏ معلومات الحالة بمعنى أنه يجب اللجوء إلى طريقة أخرى لتحقيق هذا الغرض . 


كان المطورون في النسخة السابقة ل 1٤5P.Nه‏ وهي ۸6۶ يستخدمون طرق مختلفة منها الكعكات لتتبع المستخدمين والتعرف 
عليهم باستخدام ما يسمى 5S£5510[N_12‏ لاستعادة المعلومات المخزنة على المخدم والخاصة بهذا المستخدم. 
لكن هذه الحلول تعتبر غير مناسبة في أغلب التجهيزات المحمولة كون المستعرضات في هذه التجهيزات لاتدعم الكعكات. 


إلا أن P.۴٤1‏ وفرت مجموعة من الآليات المختلفة للحفاظ على الحالة بعضها استمرار لما تم استخدامه في ۴؟۸8 وبعضها جديد. 
هذه الآليات هي التالية: 
حالة الجلسة : تسمح بالمحافظة على المتحولات والأغراض ضمن غرض ١٥1ءءع$‏ في حال وجود عدة طلبات واستجابات. 
المتحولات المخفية: تسمح هذه المتحولات بإدامة قيم المتحولات والأغراض عن طريق إعادة إرسال البيانات للزبون من 
خلال حقول مخفية. 
4‰ س۷1 : تسمح بالحفاظ على القيم الخاصة بنموذج وب محمول على المخدم. يقوم محرك زمن التشغيل بتخزين 
المعلومات ضمن متل من الصف ع4 8ءع)ه)6.01.5ءm.۷ءعtءر؟‏ والذي يتم تخزينه ضمن غرض ١10ءءع8.‏ 
٠ه‏ حالة التطبيق: تساعد في الحفاظ على المتغيرات والأغراض الخاصة بتطبيق عبر عدة طلبات من عدة زبائن. 
تتطلب الطرق الثلاث الأولى من المخدم التعرف على زبون ليتمكن من متابعة طلباته المتتالية مما يستلزم إرسال مُعرف وحيد إلى 
الزبون مع كل استجابةء يقوم الزبون بدوره بإرساله مع الطلب التالي. في المستعرضات المكتبية العادية یمکننا استخدام کعکات H۲۲۶‏ 
أما في المستعرضات التي لا تدعم الكعكات فيتم استخدام ما يسمى بمُعرّفات 0۸1ا المطعَمة وهي عبارة عن عناوين ا0 تمت 
إضافة مُعرف فريد إليها ليميز الجلسة. 


ا 


توفر ۸8۴.٤1‏ كما ذكرنا نسخة محسنة عن غرض ٥وو‏ المستخدم مسبقاً مع ۸8۴ والذي يسمح بإجراء المهام التالية: 
التعرف على المستخدمين من خادل مغرف اصن بالجاية. 
تخرين رمات خا كه اة 
إدارة دورة حياة الجلسة من خلال طرق معالجة للأحداث. 


تحرير بيانات الجلسة بعد مضي زمن محدد. 


هناك ميزتان أساسيتان لهذا الحل 
= الأولى: عندما يتولى مخدم الاستجابة لطلبات متتالية من نفس الزبون حيث يمكن اعتماد مخدم محدد لتخزين معلومات 
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الجلسات مما يسمح بالحفاظ على الحالة أياً كان المخدم الذي يستجيب لطلب الزبون. 
- الثانية: إمكانية تخزين معلومات الجلسة على قاعدة بيانات 56۲۷6۲ 5Q1‏ مما يسمح باستعادة معلومات الجلسة في حال 
انهيار النظام أوإعادة تشغيل مخدم 118. 


أهم الطرق والخصائص التي يقدمها غرض ١10ءءع؟‏ هي: 


الخاصة أوالطريقة 
الطريقة Abandon‏ 


الطريقة ك۸ 
الطريقة ٣2ءاC‏ 


Remove الطریقة‎ 
RemoveAll ةãيرطلl‎ 


RemoveAt ةقãيرطÙلl‎ 


Count ةصاخلl‎ 
IsCookieless ةصاخll‎ 


IsNewSessi0n ةصاخll‎ 


IsReadOnly ةصاخll‎ 


IsSynchronized ةصاژخll‎ 


الخاصة كرإعمk‏ 


الوصف 

تقوم بإهمال غرض ١٥اءءم؟‏ الحالي وتحرير 
معلوماته. 

إضافة عنصر . 

تقوم بمسح معلومات الجلسة ولكن لا يقوم بإهمال 
غرض الجلسة. 

تقوم بإزالة غرض من معلومات الجلسة الحالية. 

تقوم بإزالة جميع العناصر من غرض الجلسة الحالية. 
يقوم بإزالة العنصر ذي الدليل المحدد من غرض 
الجلسة الحالية. 

تعيد عدد العناصر التي يتضمنها غرض الجلسة الحالية. 
تعيد قيمة منطقية تحدد فيما إذا كانت الجلسة تدعم 
الكعكات أم لا. 

تعيد قيمة منطقية تحدد فيما إذا كان الطلب هوالأول 
ضمن الجلسة. 

تعيد قيمة منطقية تحدد فيما إذا كانت معلومات الجلسة 
مخصصة للقراءة فقط. 

تعيد قيمة منطقية تحدد فيما إذا كانت الجلسة آمنة من 
حيث إمكانية خلق سياق برمجي إضافي لها. 

تقوم بتعيين أوإعادة قيم عناصر الجلسة. 
Session[“keyName”]=value‏ 

او 
Session [index]=value‏ 

تعيد جميع المفاتيح الخاصة بغرض الجلسة الحالية. 


استخدام غرض الجلسة 
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الخلفية لصفحة الوب المحمولة. 


مثال: 
يبين المثال التالي النص البرمجي في الخلفية للملف ×هءه.1ةطه61 والذي يأخذ الاسم كء.×4ءه.610041. سنقوم في المثال باستخدام 
طريقتين لإضافة البيانات إلى غرض الجلسة: 
٠‏ الأولى باستخدام مولد دليل بمفتاح 1۳”٠‏ ۲51۲۲ء0 لإضافة سلسلة محرفية تمثل زمن بداية غرض الجلسة. 
٠‏ الثانية باستخدام الطريقة كك۸.4٥1وءم؟‏ لتعريف دخل يستخدم المفتاح ءءء ۸م11 والذي يحمل القيمة الأولية عاه؟. 
using System;‏ 
USING SYSTEM. Collect Tons;‏ 


using System.Web; 
using System.Web.SessionState; 


namespace MSPress.MobWeb. SessEx 
{ 
public Clas GIODIL : SST eM. Wes. HETDASDpllcalion 
1 
protected void Session_Start (Object sender, EventArgs e) 


1 


Session ["UserStartTime"] =DateTime.Now. ToLongTimeString (); 
Boolean HelpAccess=false; 
Session.Add("HelpAccess", HelpAccess) ; 


يتألف ملف ×هءه.1ةطه61 الذي يشير إلى النص البرمجي السابق من موجه p110310١‏ م۸ @ وحيد: 


<%5@ Application Codebehind="Global.asax.cs" 
Inherits="MSPress.MobWeb.SessEx.Global" %> 


نلاحظ في النص البرمجي التالي لصفحة نموذج الوب المحمولة» وجود عنصري تحکم :۴0۲٣‏ 

٠‏ يوجد في النموذج الأول ۴۲١۳١1‏ زر وعنصر تحكم 14٥11‏ بحيث يجري تحديد قيمة 1٥×‏ لعنصر التحكم 12٤11‏ ضمن 
النص البرمجي في الخلفية. 
يوجد النموذج الثاني ۴١۲۳2‏ عنصري تحكم 1.0٤1‏ أحدهما يحدد كون هذه الصفحة هي صفحة مساعدةء أما الثاني فهوفارغ 
ويجري إسناد قيمة له في النص البرمجي العامل في الخلفية. 


project <%5@ Register TagPrefix="mobile" 

Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 

<%@ Page language="c#" Codebehind="MobileWebForml1.aspx.cs" 

Inherits="MSPress.MobWeb.SessEx.Mobi leWebForml1" %> 


MOBI le EOEM 1A FORM EUNaAE=LSevVEE LS 
<mobile Label 1d="Labelll runat="server l/> 
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MOONE SCOMMNANGA E CONAN EUNAES SERVE CES MO 
Help</mobile:Command> 
</mobile:Form> 
mol le Eom IGA LOEMZ UNA ESL SE VERS 
MOONEE LA Sel MEO EAE ZE UNA SCEVERL > 

This is a help page. 

</mobile:Label> 

<mobile:Label id="Label3" runat="server"></mobile:Label> 
</mobile:Form> 


أما النص البرمجي في الخلفية فهو : 


using System; 
using System.Web.Mobile; 
using System.Web.SessionState; 


namespace MSPress.MobWeb. SessEx 
{ 
public class MobileWebForml 
System.Web.UI.MobileControls.MobilePage 
{ 
protected System.Web. .MobileControls.Label Label1l; 
protected System.Web. .MobileControls.Label Label3; 
protected System.Web. .MobileControls.Command Commandi1l ; 
protected System.Web. MoS LE CORREO LS EOEM EOEM UL; 
protected System.Web. Mobi leCOREr OLS EOEM HOMA; 


override protected void OnInit (EventArgs e) 
ا‎ 

InitializeComponent () ; 

base.OnInit (e); 


private void InitializeComponent () 
{ 
this.Load += new System.EventHandler (this.Page_Load) ; 
ENS COMIN CULE 1= eu 
System.EventHandler (this.Command1_OnClick); 


private void Page_Load(object sender, System.EventArgs e) 
1 

Labell1.Text = "Help accessed: "; 

Labell1.Text += Session ["HelpAccess"] .ToString(); 


} 
private void Command1_OnClick (object sender, System.EventArgs 


1 


//Switch to the Help form, set the flag in Session object 
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Session ["HelpAccess"] = true; 

Label3.Text = "Help accessed: "; 

Label3.Text += Session ["HelpAccess"].ToString(); 
Net 1 VEE OEM  HOEMZ, 


عند تشغيل هذا التطبيق : 
٠‏ يتم إرجاع القيمة عءاه۴ إلى المتحول sوعءءء‏ 4م۲11 ضمن غرض الجلسة. 
٠‏ عند إظهار النموذج ۴٠١۲٣1‏ يجري تشغيل الطريقة ل2ه1ا_ععه۴ وإظهار ãيnة .HelpAccess‏ 
غك اعمال المستخدم لازن لى التموذ ج ترمل المطومات إلى المخدم إضافة إلى تفيذ طريقة معالجة الحدة 
Command _C lick‏ والتي ستؤدي إلى إسناد مإ إلى nllتحJg .HelpAccess‏ 
٠‏ عند حصول أي زيارة إلى ۴١۲۳2‏ من جديد ستظهر القيمة الجديدة لعنصر الجلسة sیعء۸م1مH‏ وهي .True‏ 


استخدام الكعكات 
تقوم آ٤p.Nء۸‏ بالتعرف على الجلسات من خلال مُعرّف 12 ضمن كعكة 1١١۴‏ والتي يجري تمريرها بين الزبون والمخدم مع كل 
طلب و استجابة. تتطلب هذه العملية استخدام مُعرف فرید ومحمي من الوصول غير المشروع. وتؤمن ASP.NET‏ هذا الأمر باستخدام 


مفتاح تشفير عشوائي يجري تغييره في كل مرة يُعاد فيها تشغيل مخدم الوب. 


يكون طول مُعرأف جلسة 32 بتاً مضافاً إليها محموعة من البيائات التي يتم تشفيرها للحصول على سلسة محارف ب 16 بتا تضمن 
هذه العملية أن يكون المُعرف 1D‏ فريد وتساعد في منع المخترقين من تخمين الخوارزمية المستخدمة لإنشائه. 


توفر الكعكات طريقة فريدة لمخدم الوب للتعرف على المستخدمين المتصلين سلكياً كمستخدمي مستعرضات ا1 1[1. ولكن فرص هذه 
الآلية ضعيفة بالنسبة للمستخدمين اللاسلكيين كون أغلب التجهيزات المحمولة لا تدعم الكعكات. على أي حال» عند وجود احتمال دخول 
زبائن لا تدعم مستعرضاتهم الكعكات إلى تطبيقاتناء يتوجب علينا استخدام مُعرقات 0۸1 المطعمة عوضاً عنها. 

استخدام مُعرأفات 0۸1ا المطعمة: 

يمكننا تطعيم مُعرفات 1081 لتمرير محدد 12 بين الزبون والمخدم بدلا من استخدام الكعكات. 

نستعرض في الصيغة التالية مثال على مُعرف 0R‏ مُطعُم: 


http://microsoft.com/myapp/(dcdbO0uvhclb2b145ukpyrr55)/index.aspx 


عند تلقي مخدم الوب الطلب يقوم بانتزاع الطعم منه وعندها يتم استخدام هذا المُعرأف كما تستخدم الكعكات. 


لاتعتبر المُعرفات المطعّمة حلا أمظياء إذ تواجه العديد من أنواع المستعرضات مشاكل في التعامل مع هذه المُعرّفات وبالأخص في حالة 
المُعرّفات النسبية وغير المطلقة. لذلك يجب المحافظة على خيار الكعكات متاحاً. 
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مثال: 


يمكننا تعطيل الكعكات بسهولة بهدف استخدام مُعرأفات 0۸1 المطعمة كبديل وذلك بإسناد قيمة للواصفة ءءعاعن)مهء التابعة للعنصر 
session State‏ ضمن ملف ع1؟«هء. ا۷ كما يوضح المتال التالي: 


<l COREIOUEaAEION delta lS > 

<sessionState 
mode="inProc"™ 
stateConnectionStriIng="tCpiIBD=12171.0.0.1:42424 
sqlConnectionString="data source=127.0.0.1;user id=sa;jpassword=" 
cookieless="true" 
timeout="20" 

> 


GI == OES COME LEUEAELOM CEE LS =>‏ 
لمنع معالج الحالة من تفعيل الكعكات يمكن وضع النص البرمجي المخصص لهذه الحالة ضمن الكتلة البرمجية التي يجري تنفيذها 


عندما تأخذ sءع]عi)مه!]‏ القيمة 1۲٠٥‏ كما يلي : 


(Session. IsCookieless) 


استخدام المتحولات المخفية 
يلزمنا في بعض الأحيان تمرير كمية صغيرة من المعلومات بين صفحات الوب دون استخدام غرض ١10كءع؟.‏ 


فعند الحاجة على سبيل المتال إلى جمع معلومات عن طريق نموذج متعدد الأجزاء عادة وباستخدام 111 نلجأ إلى استعمل التأشيرة 
<اام«ن> مع الواصفة ءمرآ التي نسند إليها القيمة ١ء111‏ لتمرير المعلومات من جزء لآخر. 


ولكن تختلف الأمور في ۷۷ إذ يجب التفكير مثلا في وضع المتحولات ضمن خبىء المستعرض تم إرسالها إلى المخدم حين 
انتهاء المستخدم من ملء جميع أجزاء النموذج. 


تساعد الخاصة ءع1طة¡ar‏ ۷ Hidden‏ للصف ععه۴ءاiاMo‏ في هذه الوظيفة حيث تسمح بتخزين ننائيات مكونة من اسم وقيمة» ومن 


تم يجري تمريرها بين المخدم والزبون كحقول مخفية. 


نستطيع الوصول إلى الوظيفة المذكورة باستخدام غرض «ه٥اوءم؟‏ أيضاً لذا يمكن أن نتساءل عن دور المتحولات المخفية ومكان 
استخدامها. للإجابة على هذا التساؤلء يجب الانتباه إلى أن هذه الآلية تشكل أحد بدائل تمرير البيانات بين الصفحات ولكنها فعالة فقط 
عندما يکون حجم البیانات صغیرا بسبب استھلاکها لم کبیر من عرض الحزمة إضافة إلى محدودية الحجم الأقصى للمنصة التي 
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تدعمها التجهيزات المتوافقة مع ۷4۴ والذي لا يجب أن يتجاوز 1.468. 


مثال: 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 
Assembly="System.Web.Mobile" $%>‏ 
Page language="c#" Codebehind="MobileWebForml1.aspx.cs"‏ @%5< 
Inherits="MSPress.MobWeb.HidVarEx. Mobi lLleWebForm1"‏ 
AutoEventWireup="false" %>‏ 


MOON le: EOD 1A HOEMIL EUNAE = Set Ve L> 
<mobile:Label id="Label2" runat="server">Your name:</mobile:Label> 
<mobile:TextBox id="TextBoxName"™ runat="server"></mobile:TextBox> 
<mobile:Command id="Command1" runat="server"> 
SUOMI 
</mobile:Command> 
mobile E OEM 


MOON IES EOEM IA LEORMZ UNA =1 Se VEL 
MOON UE Label MA Label lL EUNAE = SERTE lS 
Your e-mail: 
</mobile:Label> 
<mobile:TextBox i1d="TextBoxEmail" runat="server" /> 
<mobi le : Command 1d" COomnand2l! TUNat= Server l> 
UNO 1 
</mobile:Command> 
</mobile:Form> 


MOOI LE EOE IA LEORMSL UNA = SEO VEL 
<mobile:TextView id="TextViewl" runat="server"> 
TextView 
</mobile:TextView> 
</mobile:Form> 


أما النص البرمجي في الخلفية فهو : 


using System; 

USING SVS EM. OIE IONS, 
using System.Web; 

using System.Web.Mobile; 

using System.Web.SessionState; 


namespace MSPress.MobWeb.HidVarEx 

{ 
public class MobileWebForml 

System.Web.UI.MobileControls.MobilePage 
{ 


protected System.Web.UI.MobileControls.Form Form2; 
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protected System.Web. 1leControls.Command Command1l ; 
protected System.Web. i LeCORNE EOS Command COmMmand 27 
protected System.Web. MoS LE CORELOLS  EOEM HOES, 

protected System.Web. .MobileControls.TextView TextViewl; 
protected System.Web. .MobileControls. TextBox TextBoxName; 
protected System.Web. .MobileControls.TextBox TextBoxEmail; 
protected System.Web. ‘MoS LE COREEOLS EOEM EOEM UL; 


public MobileWebForml () 
{ 


Page.Init += new System.EventHandler (Page_Init); 


private void Page_Init (object sender, EventArgs e) 


1 


InitializeComponent () ; 


ptivate void InitializeComponent () 


{ 
EMAL S ¢ COMMENCING 4— 

new System.EventHandler (this.Command1_ Click); 

EIRLS COMM ENAA ¢CILAE = 

new System.EventHandler (this.Command2_ Click); 

ERIS HOMO ACEI VA Eê 1— 


3 


new System.EventHandler (this.Form3_Activate) ; 


} 


private void Command1_Click (object sender, System.EventArgs 


1 


HiddenVariables.Add (TextBoxName. ID, TextBoxName. Text) ; 
EDS. ACE VEE OEM E SEMA, 
} 
private void Command2_Click (object sender, System.EventArgs 
{ 
HiddenVariables.Add (TextBoxEmail. ID, TextBoxEmail. Text) ; 
EDA S ACEI CE ORME OEMS 


} 


private void Form3_Activate (object sender, System.EventArgs 
1 
SErIng FormDalta mY; 
foreach (Object o in HiddenVvariables.Keys) 
{ 
HO MDa a t=O. OSE INO () 11 THiIGdenVar i ables (Ol FI<OE> lL; 


1 
TextViewl.Text=FormData; 
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وتكون النتيجة النهائية لتنفيذ هذا المثال على الشكل: 


Tour name: 0 Your e-mail: TextEoxEmail 
Andy Yigley] | EEE 011 [ andywmEcontentmaster. | 
Submit | com 


| TextBoxName Andy 


ViewState مlدختصl‎ 


توحي ۸8۴.٤‏ للمستخدم بإنطباع يفيد بإمكانية الحفاظ على الحالة للصفحات عبر عدة دورات بين المخدم والزبون. في الحقيقة لا 
تستمر معلومات الصفحة لأكثر من طلب أواستجابةء ولكن ما يحصل هوتخزين خصائص الصفحة والخاصة عاه)؟ سه۷ لكل عناصر 
تحكم المخدم فيها إلى مثل من الصف ع۵84 اهاS.‏ 


عندما يقوم المستخدم بإرسال طلب تجري عملية إعادة بناء الصفحة آلياً باستخدام قيم الخصائص ضمن مثل الصف عه8عاها؟. 


يكون مجال رؤية الخاصة 5)٥‏ س۷1 هوغرض مع۴4ء1طاهM‏ الحالي الذي يتضمن ملف ×صءه والبرنامج العامل في الخلفية. لذلك 
لن نستطيع استخدام الخاصة ء)ه)5سع۷1 في حال كان التطبيق ينتقل من غرض عءع۴4ءi1طاه‏ إلى آخر سواء باستخدام إعادة توجيه 
(MobilePage.Response.Redirect(“ URL”) ةڌيرط¦آJl مIدختulب) HTTP‏ أو بنقل التحكم إلى صفحة أخر ى باستخدام الطريقة 
.(MobilePage.Server.Transfer(‘URL”)‏ 


يوضح المثال التالي كيفية حفظ خاصة ضمن ا)5 ۷٠W‏ وكيفية استعادتها لاحقا: 
using System;‏ 
using System.Web;‏ 
using System.Web.Mobile;‏ 
USING SYSTEM. Web. UIL.MobileConirols;‏ 
using System.Web.UI;‏ 


public class MobileWebForml : System.Web.UI.MobileControls.MobilePage 
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protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls.Label Label1l; 


// MyMessage property get and set accessors 
// using the ViewState property 
public String MyMessage 
{ 
GEE 
1 
1 Elicit CT EO SEIT 
return (String) ViewState ["MyMessage"]; 


ViewState ["MyMessage"]=value; 
} 


private void Command1_ Click (object sender, System.EventArgs e) 
1 
// Consume the persisted property. 
Label1.Text=this.MyMessage; 


تكون الخاصة ها5 س۷1 مفعلة بشكل تلقائي في عناصر التحكم من جهة المخدم وصفحات الوب المحمولة. فإذا قمنا بإلغاء تفعيل 
الخاصة هس۷1 ضمن أحد عناصر التحكم سيتم تلقائياً إزالة تفعيلها بالنسبة لكل عناصر التحكم المحتواة ضمن هذا العنصر. 


لإلغاء تفعيل عمل هذه الخاصة يكفي إسناد ع۴۵ إلى الواصفة عاھ)؟W‏ ع۷1 e‏ 1ا۴2 ضمن تأشيرة عنصر التحكم من جھة المخدم كما 


<mobile:Label i1d="Labell" runat="server" EnableViewState="Ealsel"l/> 


ولإلغاء تفعيل هذه الخاصة ضمن كامل الصفحة يكفي استخدام الصيغة: 
Page language="c#" Codebehind="MobileWebForml1.aspx.cs"‏ @%< 
Inherits="MobileWebForm1" EnableViewState="False" %>‏ 


عادة ما يلجأ المطورون إلى إزالة تفعيل هذه الخاصة لتسريع عمل التطبيقات وذلك ضمن التطبيقات السلكية لأن هذه الطريقة (كما هي 
الحال مع استخدام المتحولات المخفية) تقوم بإرسال كم كبير من البيانات بين الزبون والمخدم مما يشكل عبء على الشبكة. 


لما كانت هذه هي الحال بالنسبة إلى التطبيقات السلكية فالمنطقي أن يتحول استخدام هذه الآلية إلى مشكلة حقيقية في التطبيقات 
المحمولة عند أخذ محدودية عرض الحزمة بعين الاعتبار. لذلك تم تغيير آلية تطبيق عاS†2 View‏ المستخدمة ضمن عناصر التحكم 
المحمولة لتعتمد على تخزين البيانات ضمن غرض ١٥1ءءع5‏ ولا تقوم في كل مرة بإرسال كامل المعلومات إلى الزبون بل ترسل فقط 
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عند استخدام غرض ١٥1ووع؟‏ لتخزين عاه)؟سع۷1 لا بد من أن نأخذ بعين الاعتبار نقطتين أساسيتين: 
© الأولى تتعلق بزمن انتهاء حيث يجري عندها فقدان معلومات عاها؟س۷1. يمكن تحديد زمن اتهاء صلاحية الجلسة بتعيين 


: ضمن ملف التطبيق عا«هء. ا٤۷ كما هوموضح في النص التالي‎ )1"ع0اu‎ ٤ قيمة للواصفة‎ 
CONE IIa 
<system.web> 
<sessionState 
mMOedle > LAM EEOC 
cookieless="true" 
timeout="20" 
/> 
</system.web> 
€ CORE 1E UE EÊ LOME 


€ أما النقطة الثانية فتتعلق بالمعلومات المخزنة في الجلسة وتطابقها مع الصفحة الحاليةء إذ قد نرى سيناريومن عدم المزامنة 


بين قيمة 5)40 س۷1 المخزنة في غرض الجلسة والصفحةء فإِذا انتقل مستخدم من صفحة إلی أخری ثم استخدم زر Back‏ 
وعاد إلى الصفحة السابقة ستكون قيمة ماه) 5س ع۷1 هي تلك الخاصة بالصفحة الثانية وليس الحالية. 


تم حل هذه المشكلة باستخدام الواصفة H1s)0]¥51z7eعssion5tatهء‏ الخاصة بعنصر ك1٥on)r€ءاbiامصہ‏ ضمن ملف 


Web.conf£‏ حسب ما يظهر في النص البرمجي التالي: 
COREL aLIOR‏ 
<system.web>‏ 
<mobileControls sessionStateHistorySize="10"/>‏ 
<system.web>‏ 
CORE LO ULE LORS‏ € 


حالة التطبية 
يعرف التطبيق في ۸5۴.٤1‏ بأنه كتلة جميع الملفات التي يقوم محرك زمن التشغيل باستخدامها أوتشغيلها ضمن مجال الرؤية 
الخاص بالمجلد الافتراضي وجميع المجلدات الفرعية ضمنه. ويحتاج المطور في بعض الأوقات إلى توليد أمثال عن المتحولات 
والأغراض التي تملك مجال روية يغطي التطبيق عوضاً أن يكون محدودا على مسثوى الجلسة. لذا يوفر الصف 
System. Web.Http A pplicationState‏ الأمكانية المذكورة للمطورين. 


يمثل الغرض ١٥1اهء‏ نام م۸ التطبيق بحد ذاته ويتم إنشاؤه حال إرسال أول طلب إلى ملف ضمن المجلد الافتراضي الخاص بالتطبيق› 
ويمكن الوصول إليه باستخدام الخاصة Application ةصاخلls System. Web.HttpApplication زصl Application‏ للصف 
.MobilePage‏ 
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يمتلك غرض ١٥1اةءامم4‏ نفس الطرق التي رأيناها ضمن الغرض «١٥1ءءم؟‏ لذلك يمكن استخدامه بطريقة مشابهة مع مراعاة فكرة 
كون المعلومات التي يخزنها غرض ١٥1اهء1امم4‏ تبقى مخزنة بين الطلبات المرسلة من عدة مستخدمين وتكون متوفرة لجميع 
مستخدمي التطبيق. 


يبقى الغرض ١4110ء1ام‏ م4۸ ضمن ذاكر ة المخدم حتى يقوم المستخدم بإيقاف عمل المخدم أوبتعديل أوتحديث ملف ×هءه.41طه61. 
استخدام حالة التطبيق ضمن الملف ×هءه.اوطه[إ6: 


يمكنك التعامل مع البيانات ضمن غرض ١٥21ء1اممه‏ باستخدام النص البرمجي في ملف ×هءه.اهطه1ن الذي يتوضع ضمن الملف 
الجذر في لمجا الأفثراضي: يمكفنا أيضاً الل مم مغلومات اة التطبيق من خلال الوخدة الأمطية العامة في الخافية لاص البرمجي 


.Global.asax 


يوضح النص البرمجي التالي استخدام غرض ١٥!4)1ء1امم۸‏ ضمن الملف ×هيه.1وbها6:‏ 


using System; 

using System.Collections; 
using System. ComponentModel; 
using System.Web; 


namespace MSPress.MobWeb. AppObjEx 
{ 
CUBDIIC CIS: GlODAL : SISTEM. WEDS. IC CDADpILCA ION 
{ 
protected void Application_Start (Object sender, EventArgs e) 
{ 
// Declare and assign a value to the global variable. 
String AppStartTime = DateTime.Now. ToLongTimeString () ; 
// Add the global variable to the Application object. 
Appll1cation [TAppStartTime™"] = AppStartTime; 


نلاحظ هنا أننا استخدمنا ٤۲٤؟_10۸ا4ء‏ امم كمعالج لحدث بدء عمل التطبيق. كما قمنا في بداية النص السابق بتحديد الملف الممثل 
للوحدة النمطية العاملة في الخلفية وذلك باستخدام : 


<%5@ Application Codebehind="Global.asax.cs" 
Inherits="MSPress.MobWeb.AppStateEx.Global" %> 


وكا ف اوخو الي مات ركن اا مو ى فة وه ا الي ا ق ون ر رن ر ن 
اراج رل ق سول السك لكل اة قم ارس إلى الك خت كط ون لار سال اها الودج اقاي قر كن انه 
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Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" $%> 

Page language="c#" Codebehind="MobileWebForm1.aspx.cs" 


Inherits="MSPress.MobWeb.SharedApplicationStateExample.Mobi leWebForm1" 
>> 
MOON LE £ FOC GVO ML EUNAE =H SEK WEES 
<mobile:TextBox id="TextBox1" runat="server"></mobile: TextBox> 
<mobile:Command id="Command1" runat="server">Enter</mobi le: Command> 
MOB LE EE OEMS 


MOBILE EOEM 1A EORMZ EUNaAE= SELE L> 
<mobDi le :Label 1da="Labelll FUnNnat—"serveFEFl label < AmMOb1 Le : Lae 1 > 
</mobile:Form> 


أُما الوحدة النمطية في الخلفية فهي : 


using System; 

USING SVS EM. COIIECT IONS; 
using System.Web; 

using System.Web.Mobile; 

using System.Web.SessionState; 


namespace MSPress.MobWeb. SharedApplicationStateExample 
{ 
public class MobileWebForml 
System.Web.UI.MobileControls.MobilePage 
1 
protected System.Web.UI.MobileControls.Command Command1l ; 
protected System.Web.UI.MobileControls. TextBox TextBoxl; 
protected System.Web.UI.MobileControls.Form Form2; 
protected System.Web.UI.MobileControls.Label Label1l; 


override protected void OnInit (EventArgs e) 
{ 

InitializeComponent () ; 

base.OnInit (e); 


private void InitializeComponent () 


1 


Command1.Click += new 
SYS EeM EventHana ler (ENIS COmMnNanal CICK), 
1 


private void Command1_Click (object sender, System.EventArgs e) 
{ 
NEI VEER OEM MOEA, 
Label1.Text = "Previous User: " + 
ABP E CAE OR LEAS EUSEEL CTO EEARS DS 
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يوضح الشكل التالي نتيحة تنفيذ التطبيق السابق: 


Peter Roxbuirg Previous Liser; Nobody 


1 
| 
ُ 
| 
4 
ا 
ُ 
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الموضوع الثاني: تحسين الأداء 


الكلمات المفتاحية: 
اداي حالة» غرض. 


ملخضص: 
إن أداء التطبيق وسرعته جزء أساسي من ضرورات الوصول إلى رضا المستخدمين عن هذا التطبيقء سنعالج في هذا الموضوع أهم 
النقاط التي قد تساعد على تحسين الأداء. 


أهداف تعليمية: 
يتعرف الطالب في هذا الفصل على: 
ه٠‏ أهم النقاط الواجب مراعاتها لرفع أداء التطبيقات. 


.۸8۲۴.×۴۲ أنواع الخبئ في‎ ٠ 
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تحسين أداء التطبيق 


ف اقيق افاس ات قطن لى سق رطاف كن اقطري رن تة الل بسك كرون طا کل اقل ک 
إدخال من المستخدم. 


مهما تكن عملية تطوير التطبيق ذكية وتحقق الوظائف فإن التطبيق لن يحظى باهتمام المستخدمين إذا كان بطيئًا. لذلك سنحاول تغطية 
بعض الملاحظات التي تساعد على منح التطبيق أداء أعلى. 


تحسين أداء التطبيق 


© إطفاء دعم إزالة العلل في النسخ التي تقوم ببنائها: 

الطريقة الأولى لتحسين الأداء هي التأكد من إطفاء دعم إزالة العلل في النسخ المبنية لأن وجودها سيؤدي إلى زيادة زمن الاستجابة 
كون محرك زمن التشغيل يقوم بمعالجة الطلبات باستخدام معالج آني. لإزالة تفعيل هذه الخاصة يجب إجراء التعديلات التي 
يظهر ها النص البرمجي ضمن ملف Web.config‏ 


CONE ULAEIOR 
<system.web> 


<EOMpA 1 aE AORN dEBUO= Lf al Sel /> 


</system.web> 
€ COME LO UE EE LOM 


€ إلغاء تفعيل 5٤٤٠‏ س۷1 في حال لم تكن ضرورية: 
ذكرنا أن استخدام مه5 س۷1 يستهلك بعض الموارد أثنا عمل التطبيق لذلك فإلغاء تفعيله في حال عدم الحاجة إليه سيوفر هذه 
الموارد وبالتالي سيرفع الأداء. 


© إلغاء تفعيل حالة الجلسة عند عدم الحاجة إليها: 
اكان اقطرق و مكح ارات ا فنا غركن اجا فق غا تقل عل عا اة اا 


<%@ Page EnableSessionState="false" %> 


€ إجراء عملية خبئ للبيانات ضمن غرض ٥١‏ اهام م ۸: 

قد يشغل زبائن الوب المختلفون نفس التطبيق ويحاولون الوصول إلى نفس الموارد في نفس الوقت. أحد تقنيات التحسين المستخدمة 
في هذه الحالة هي تأمين مشاركة مجموعة المصادر المتكررة الاستخدام وغير المتغيرة بشكل كبير» للقراءة فقط وذلك بخبئ 
البيانات ضمن غرض ١٥210ء1امم۸‏ عند تشغيل الطريقة S4۲١‏ _١٥!a)1ء1اممA‏ ضمن الملف ×هءه.|إوbهاG.‏ 
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في هذه الحالة يقم كل إجراء بخدم زيون بالرصول إلى البياات من خلال خرض فف اة6تام مه دون الاضطراز إلى اكماد 
المعلومات من المصدر الأصلي. يوضح نص المتال التالي خبئ الغرض 1ء٥145‏ ضمن غرض ١٠٥1اه4ء1امم4‏ وذلك من خلال 
الطريقة S41۲٤‏ _۸٥10)ءcه1اممA‏ ضمن الملف ×جءھ.ba1هGl:‏ 


OuOLAE voll Aol IECAE 1O OEE E (0) 

{ 
// Create the data component . 
AuthorsDataComponent.AuthsComponent myDataComp = 
new AuthorsDataComponent.AuthsComponent () ; 


// Use the data component to fetch a DataSet. 
AuthorsDataComponent.AuthsDataSet ds = myDataComp.ALLIAuthors; 


// Store the data source in the application state so that 
// the data source is available to all clients. 
Application ["AuthsDataSet"™"] = ds; 


عندها يمكن لأي غرض أن يصل إلى البيانات عن طريق غرض ١٥1ا4ءنام‏ م۸ ضمن طريقة ل1.04_#ع۴4 للصفحة عوضاً عن 
جلب البيانات من قاعدة البيانات مرة أخرى. 


void Page_Load(Object sender, EventArgs e) 


DataSet sourceDS = (DataSet) (Application ["AuthsDataSet"]); 


ESE I Dat aSOUECGe > SOMECEeDSE 
MASE Il DataMember — SUEROESL, 


© إطفاء دعم إزالة العلل في النسخ التي تقوم ببنائها: 
الطريقة الأولى لتحسين الأداء هي التأكد من إطفاء دعم إزالة العلل في نسخ المبنية لأن وجودها سيؤدي إلى زيادة زمن الاستجابة 
كون محرك زمن التشغيل يقوم بمعالجة الطلبات باستخدام معالج آني. 


€ إلغاء تفعيل ٠٤ة٤؟‏ س۷1 في حال لم تكن ضرورية: 

ذكرنا أن استخدام 8ا٤5‏ س۷1 يستهلك بعض الموارد أثنا عمل التطبيق لذلك فإلغاء تفعيله في حال عدم الحاجة إليه سيوفر هذه 
الموارد وبالتالي سيرفع الأداء. 

© إلغاء تفعيل حالة الجلسة عند عدم الحاجة إليها: 

إذا كان التطبيق لا يستخدم الوظائف التي يقدمها غرض الجلسة يفضل إلغاء تفعيل عمل حالة الجلسة أيضا. 

€ إجراء عملية خبئ للبيانات ضمن غرض ٥١‏ ااام م ۸: 

قد يشغل زبائن الوب المختلفون نفس التطبيق ويحاولون الوصول إلى نفس الموارد في نفس الوقت. أحد تقنيات التحسين المستخدمة 
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في هذه الحالة هي تأمين مشاركة مجموعة المصادر متكررة الاستخدام غير المتغيرة بشكل كبير للقراءة فقط وذلك بخبئ البيانات 
ضمن غر ض ١٥1ا4ء1امم۸‏ عند تشغيل الطريقة S2۲۲‏ _۸٥1ا1aاممA‏ ضمن الملف ×هءه.إbaهاG.‏ 

في هذه الحالة يقوم كل إجراء يخدم زبون بالوصول إلى البيانات من خلال غرض ١٥اةنامم4‏ دون الاضطرار إلى استعادة 
المعلومات من المصدر الأصلي. 


تحسين أداء التطبيق 


ڪڪ 


€ استخدام التقسيم المخصص إلى صفحات: 

في حالة تحميل أغراض 4486( الكبيرة ضمن عناصر تحكم Select ist, 1s‏ و bjet ist‏ أوعندما یتطلب تولید عناصر 
القائمة عمليات حساب معقدة» يجب التفكير باستخدام التقسيم المخصص إلى صفحات. في هذا النوع من التقسيم يجري تزويد 
العنصر حين إظهاره بالمحتويات فقط مما يوفر وقت الحساب الطويل لكامل محتوى عنصر التحكم. 


© عدم إجراء عمليات معالجة غير ضرورية عند عملية إعادة إرسال الصفحة : 
من هم تقنيات تحسين الأداء استخدام الخاصة )ع2 s)8ء۴0ء1.معP۴aعاMobi‏ لتجنب عمليات المعالجة غير الضرورية على 
البيانات» وذلك للتحقق من تنفيذ عمليات المعالجة في المرة الأولى لتحميل الصفحة وليس في كل مرة يتم إعادة إرسال الصفحة. 


€ استخدام الطريقة System." ext .StrinعBui[d e٣‏ لجمع السلالسل المحرفية: 
تعتبر هذه الطريقة أسرع من استخدام إشارة الجمع (+) لدمج السلاسل المحرفية وبالأخص في التطبيقات التي تتضمن الكثير من 
عمليات دمج سلاسل المحارف تلك. 
StringBuilder detailText = new StringBuilder ();‏ 
detailText.Append("This block of text ");‏ 


detailText.Append("will be <b>displayed</b> in a "); 
detailText.Append ("TextView Control."); 


TextViewl.Text = detailText.ToString(); 


€ ضبط الوصول إلى بيانات مخدم .501 بالشكل الأمثلي: 
تساعد عملية استخدام الإجرائيات المخزنة للوصول إلى البيانات بشكل كبير في زيادة الأداء بشكل ملاحظ. كذلك هي الحال عند 
استخدام الأغر |ض DB DataReadery SqlDataReader‏ في الحالات التي لا تتطلب وصول مخصص للكتابة أو التحديث. 


€ التصريح عن أنماط الأغراض في Visual Basic.NET‏ 

هناك طريقة أخيرة لزيادة أداء التطبيقات بالنسبة للمطورين الذين يستخدمون ئ8 اهسء¡۷ وهي إسناد #نء) إلى الواصفة 
التي تحدد ضرورة التصريح عن جميع أنماط الأغراض قبل استخدامها مما يوفر الوقت على محرك زمن التشغيل في 
التعرف على أنماط البيانات المختلفة المستخدمة. 
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<C EaGe Lano e MEL SEIU > 


الخ ء 


۰ 


توفر ۸8۴.٤1٣‏ ثلاث طرق للخبئ يمكن استخدامها لتحسين الأداء هي : 
€ خبئ الخرج. 
© الخ المحزة 
© خبئ البيانات. 


خبئ الخرج: 

يمكننا استخدام الخبئ للصفحة باستخدام الموجه ٣2٥1‏ ام0 @ في رأس صفحة نموذج الوب المحمول: 
OutputCache Duration="60" VaryByParam="none"™$%>‏ @%< 

تحدد الواصفة ١٥ناهإu‏ عدد الثواني الذي يتوجب على 115 خبئ المعلومات فيه. 

بوجود هذه العبارة في رأس الصفحة يحدد محرك زمن التشغيل فيما إذا كان يتوجب إرسال النسخة المخبئة أم إعادة توليد الصفحة 

بمقارنة سلسة محارف lالٹمحدد .HTTP_User_Agent‏ 

يجري إرسال سلسة المحارف هذه مع كل طلب لتعريف نمط المستعرض المستخدم. فإذا تم طلب صفحة ما مخبأة وهي مخصصة لنفس 


نوع المستعرض» ولم تنته صلاحيتها بعدء يجري إرسالها عوضاً عن إعادة توليدها من جديد. 


يوضح المثال التالي هذه الفكرة: 
OutputCache Duration="60" VaryByParam="none"$%>‏ @%< 
Register TagPrefix="mobi le"‏ @%5< 
Namespace="System.Web.UI.MobileControls"‏ 
Assembly="System.Web.Mobile" $%>‏ 
Page Inherits="System.Web.UI.MobileControls.MobilePage™‏ @%5< 
Language="c#"%>‏ 


<html> 
<head> 
<script language="c#" runat="server"> 
public void Page_lLoad(Object sender, EventArgs e) 
{ 


l1lblTime.Text = "Page Loaded at: " + 
DateTime.Now. ToLocalTime (); 


} 


€ SOE LOE > 
</head> 


OO 
<mMOoObN LE: BOEM rUNaAE=LSeEVEEL 1d E EMMaAIRLS 
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<moOi le: Label 1a6 Ilmimel SUNA SERVE l1, 
</mobile:Form> 
€ OCS 
CAMELS 


عند تشغيل هذا التطبيق وتحديث الصفحة لأكثر من مرة أومحاولة الوصول إلى الصفحة من نفس نوع المستعرض» لن يتغير الزمن 
الظاهر على هذه الصفحة لمدة 60 ثانية ( أي لن يعاد توليد الصفحة في هذا الوقت). يجب أن يتضمن الموجه @OutPutCache‏ 
الواصفة ۷۲8/۲2۲۳ ويمكن أن يتضمن بشكل كيفي الواصفات VaryBy H261‏ وustom€VaryBy‏ وفيما يلي شرح 
لاستخدام کل منها: 
€ n؟وإو8y۴,اه۷:‏ استخدامها إلزامي كما رأينا. وهي تستخدم لتحديد قيمة أوأكثر ليتم إرسالها من الزبون إلى المخدم 
کمعامل عن طریق ۴051 ار .6٤1‏ 
إذا تم تعيين قيمة هذه الواصفة إلى 10١8‏ سيقوم محرك زمن التشغيل بخبئ طلب 6٤١‏ الأولي إلا في حال تمرير المستخدم 
لمحددات أخرى عن طريق عنوان 081 بعد الإشارة (7). 
إذا أردت في هذه الحالة خبئ الصفحة الناتج باستخدام المعلومات المرسلة لا بد من تحديد اسماء المتحولات ضمن قيمة 
الواصفة ٣2۲2۳‏ ۲y8ه۷‏ مفصولة بفاصلة منقوطة كما يظهر في المثال: 


<%@ OutputCache Duration="60" VaryByParam="selState;jtxtSearch" %> 


ولجعل الخبئ يعتمد على جميع القيم المحددة ضمن سلسلة محارف الاستعلام أوضمن المعاملات المرسلة بواسطة 1؟۲0 
يكفي إسناد القيمة (*) إلى هذه الواصفة. 


<%5@ OutputCache Duration="45" VaryByParam="*" %> 


Vary By Header‏ : تساعد هذه الواصفة في تفعیل الخبئ اعتماداً على عنصر ضمن رأُس 1۲۲۶. فعلى سبيل المثالء 
لإجراء الخبئ اعتماداً على الرأس Accept-Lan guage‏ يجب کتابة موجه u)€2c1e‏ ۴ا0 کما یلي: 


<%@ OutputCache Duration="60" 
VaryByHeader="Accept-Language”" 
VaryByParam="none" %> 


:۷arBy Custom €‏ تستخدم هذه الواصفة لتغيير الخبئ اعتماداً على نمط المستعرض المستخدم أواعتماداً على سلسلة 


تأخذ هذه الواصفة القيمة عء س80 بشكل تلقائي. 


يمكننا تعيين معرأف خبئ مخصص بإسناد القيمة المطلوبة إلى صeustom€VaryBy‏ وإعادة تعريف الطريقة 
.Global.asax J jمnض Http Application ضرغئll GetVaryByCustomString‏ 


يجب أن تعيد هذه الطريقة السلسلة المحرفية للطلب الحالى والتى سيتم استخدامها من قبل محرك زمن التشغيل لتغيير الخبع وفقاً لها. 
يجب ان تعي : : ي والتي سيتم من قبل محرك زمن 


Universal Knowledge Solutions s.a.1 
223 


يوضح المثال التالي هذه الفكرة حيث يتم تحديد الموجه عطac٣)uم0ut@‏ كما يلي : 
OutpurCache Duraltion=" o60"‏ 6< 


VaryByCustom="MySelector"™ 
VaryByParam="none" %> 


كما يجب إعادة تعريف الطريقة uso ٣5)11‏ €tiVaryByءG‏ ضمن الوحدة النمطية العاملة في الخلفية للملف ×هءه.إهbهاG‏ 


puolice override SErINnG GelVaryBYyCUSTOMSEFEING f 
BITPCONTEOXTE ConlexE, SlLILING aE) 
1 
SUA EER (AES 
case "MySelector": 
// Send back the string that is used to distinguish 
// between client devices for output caching. 
return "MySelector=" + context. Request. Browser 
COMLEX o KEC UOS Ê . Ë E MSS 7 
default: 
BE EUED 


استخدام الخبئ المجزء: 

يُعرّف الخبئ المجزء بأنه تقنية ن مع عناصر التحكم الخاصة بالمستخدم وهي مكونات ينشؤها المستخدم بقصد إعادة الاستخدام. 
يمكن استخدام هذه الطريقة من الخبئ لتخزين الخرج الخاص بعناصر تحكم المستخدم والتي قد تشكل جزء من/أوكل صفحة الوب 
المرسلة إلى المستخدم. 

من العناصر المرشحة لتستخدم هذا النوع من الخبئ: روابط الانتقال ضمن الموقع ورأس الصفحة والتذييل والأجزاء الأخرى التي 
يمكن بخبئها تحسين الأداء. 


استخدام خبئ البيانات: 


تدعم 48P۶.N٤1‏ الخبئ عن طريق الذاكرة والذي يمكن أن يُستخدم لتخزين الأغراض المختلفة بين طلبات 1۲1۴. يملك خبئ 
البيانات مجال رؤية يغطي التطبيق لذا يمكن الوصول إليه من أي جلسة ضمن التطبيق. 


يمتلك خبئ البيانات بنية الفهرس لذا يكون التعامل معه برمجياً سهل جداً. 


// Save DataSet in the data cache; has Application scope. 
Cache ["DS"] = myDataset; 


// Get EME DataSet rom Ee CGICMe. 
DataSet ds = (DataSet) (Cache ["DS"]| ) 
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القسم الثالث عشر: 


دعم زبائن جدد 


الكلمات المفتاحية: 
زبون» موائم » جهاز» ملف الإعداد» إمكانات 


ملخضص: 
في معظم الحالات» تقوم ۸8۴.٤١‏ بتشكيل صفحات نماذج الوب المحمول للزبائن بالشكل المتوقع» ولکن ۸5۴.٤۲‏ لاتدعم 
بعض المستعرضات الجديدة أوالنسخ الحديثة منها. سنستعرض في هذه الجلسة طرق دعم تجهيزات جديدة ولغات تأشير جديدة. 


أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على: 
© كيفية تعريف التجهيزات المحمولة ضمن ملفات الإعداد. 
© التعرف على الجهاز وإمكاناته. 
© طضبط و تعزيف مو امات الأجهرة: 
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دعم زبائن جدد 


في معظم الحالات تقوم ۸8۴.٤1‏ بتشكيل صفحات نماذج الوب المحمول للزبائن بالشكل المتوقع» إلا أن بعض التجهيزات المحمولة 
تعطي أخطاء أثناء العمل على التطبيق» أولا تظهر فيها صفحات التطبيق بالشكل المطلوب. 


يعود سبب هذه الظاهرة إلى عدم دعم ۸8۲.٤1‏ لمستعرض بسبب العدد الكبير من المستعرضات والعدد الكبير من النسخ المختلفة 
لکل مستعرض. إذ لن يكون من المفاجئ ألا تقدم ۸8۲.۴۲ دعما لكل هذا التنوع الكبير من النسخ والمستعرضات. 


على كل حال» تطلق ا#موهإ٥11‏ في كل فترة حزمة خاصة لدعم أنماط جديدة من المستعرضات وتحسين الدعم للمستعرضات 
المتوفرة. يمكن الوصول إلى هذه الحزمة عن طريق الارتباط 
http://www. asp.ne1/mobile /deviceupdate.aspx ?tabindex=6‏ 


لكن ماذا لوأردنا استخدام جهاز غير مدعوم بصورة رسمية بعد؟ 


لحسن الحظ تملك ۸8۴.٤1‏ بنيان قابل للتوسع يسمح بإضافة أنواع جديدة من تجهيزات الزبون. لذا سنغطي خلال هذه الفقرة الطرق 
المستخدمة لتأدية هذا الغرض . 


تعريف التجهيزات المحمولة ضمن ملفات الإعداد 


لنتمكن من إضافة دعم لزبون جديد يجب أن نفهم كيف يتم التعرف على الزبائن وكيف يجري اختيار لغة التأشير الأنسب له. 
یوضح الشكل التالي الإجراء الذي يحدد نمط الزبون ليقوم بدوره بتحديد تعريف له يكون متوفرا للتطبيق. 


يتم التأكد من تفاصيل الإعدادات 


يقوم محرك زمن التشغيل بتأهيل 
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نلاحظ في الشكل السابق أن الزبون يقوم بإرسال طلب إلى صفحة نموذج الوب المحمول. عند تلقي الطلب يجري إنشاء غرض من 
الصف اءع ١u‏ ۸م))81» ويقوم هذا الغرض بالوصول إلى الغرض كع1):اabمa٣ءMobi1‏ عبر الخاصة إعsس‏ 80 التي تحفظ 
ضمنها معلومات حول قدرات الجهاز مرسل الطلب. 

يجري بعدها فحص ملف الإعداد الخاص بالتطبيق عاگصهء.اء۷ وملف إعداد النظام عاگمهء.ع«اطعج للقسم الخاص بالعنصر 


.<browserCaps> 


إذا كنا قد ثبتنا التحديث بنسخته 2 أوأكثر فسنلاحظ أيضاً وجود هذا القسم ضمن الملف عاگصهء.ماملم لا ءء1رم( والذي يمكن إيجاده 
مع ٹف ./Microsoft.NET/Framework/version/CONF1IG دlڊanll janض› machine.config‏ 


يو ضح النص التالي القسم <كمة٣۲ءء0wW][ا>‏ ضمن ملفات الإعداد: 
<browserCaps>‏ 
<USe Uar  LHIIES USER AGENT VS‏ 
<EIIters‏ 
oI 2.‏ =1 
<case‏ 

match="Nokia.=*"> 
browser = "Nokia" 
mobileDeviceManufacturer = "Nokia" 
preferredRenderingType = "wml11" 
preferredRenderingMime = "text/vnd.wap.wml" 
preferredImageMime = "image/vnd.wap.wbmp" 
defaultScreenCharactersWidth = "20" 
defaultScreenCharactersHeight = "4" 
defaultScreenPixelsWidth="90" 
defaultScreenPixelsHeight=" 40" 
screenBitDepth = "1" 
isColor = "false" 
inputType = "telephoneKeypad" 
numberOfSoftkeys = "2" 
hasBackButton = "false" 
rendersWmlDoAcceptsInline = "false" 
rendersBreaksAfterWmlInput = "true" 
requiresUniqueFilePathSuffix = "true" 
maximumRenderedPageSize = "1397" 
canInitiateVoiceCall = "true" 
requiresPhoneNumbersAsPlainText = "true" 
rendersBreaksAfterWmlAnchor = "true" 
canRenderOneventAndPrevElementsTogether = "false" 
canRenderPostBackCards = "false" 
canSendMail = "false" 


Ê Û JÎ Ea > 
<case 
MelElER= NOK a N OAT O OG TERS ONSEN) 
type = "Nokia 7110" 
TeErSIONn = SIVE SIONSTEING} 
E J E IS 
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WIEhN=" S$ {(TeTSlonSTCrInNG FF" 

match= 

" (?'browserMa jorVerSlon'\W*) (2'BrowSserMinorVerSIORNT\. NW). T> 

majorVersion = ${browserMajorVersion} 

minorVersion = ${browserMinorVersion} 
CCT 
mobileDeviceModel = "7110" 
optimumPageWeight = "800" 
SEEOESRCMEIE ACE EE SWE =U 22 
screenCharactersHeight="4" 
screenPixelsWidth="96" 
screenPixelsHeight="44" 

</case> 
</filter> 
</case> 
Fae E, 
</browserCaps> 


نلاحظ احتواء النص السابق على عدة أقسام <#ءهء> يحدد كل منها نوع من المستعرضات المدعومة. تستخدم هذه المقاطع التعابير 
النظامية لإجراء التطابق مع متحوJ‏ بأ HTTP_USER_AGENT‏ الذي يجري تمريره عادة ضمن ترويسة طلب 11° .H‏ 


إذا تم إيجاد التطابق فيمكن عندها التعرف على المستعرض الزبون وإلا فسيتم تأهيل الغرض كع11)1¡ اهم M11٣2‏ بالمعلومات 
التلقائية المحددة في الإعددات التلقائية التي يمكن إيجادها في بداية القسم <كم2ة٣۲عءس«١0إط>‏ ضمن ملف عاfiرهء.ممiطعمص‏ الذي 


تكون عملية البحث عن مطابق للزبون المطلوب بالترتيب ابتداء من DeviceUpdate.config ylإ yلإ machine.config‏ إلى 
.Web.con‏ بحيث تلغي معلومات الملف الذي ستتم قراءته أخيرا المعلومات السابقة. 


يفضل عادة عدم وضع معلومات المستعرضات المختلفة ضمن machine.conf¡g‏ نظرا لكونه ملف حساس» لذا يفضل إدراج أي 


تحديث أو تغيير ات ضمن ملف عاگصهء.ع)هلم€اءءiرم(‏ بحيث يجري تحديد هذا الملف ضمن ملف عاگصهء.ع«نطعجمص وفق ما يلي: 


<browserCaps> 
SEESUlLE EVPe=lSVSEOM. WEB MOBI le. MoOB1 leCapaBiliE1eS, SyVStEeM WED. MOO le, 
Ver So =I. O SOOO OF, COME UEe= Ree al, 
PublicKeyToken=b03f5f7f11d50a3a" /> 
<file src="deviceupdate.config" /> 
USE VaF- HIVE USER AEENMT ys 


دعم الزبائن الجدد 


تسهّل إعدادات ۸5۴.٤١‏ المبنية كمقاطع وملفات ۷× عملية إضافة دعم لزبون جديدء حيث يمكن تعديل الملف 
machine.config‏ أو device pdate.config‏ لتأمين دعم زبون جديد على كامل التطبيقات. أما إذا رغبنا إضافة هذا الدعم ليتناول 
تطبيق محدد فیجب استخدام الملف .Web.config‏ 
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بغض النظر عن ملف الإعدادات الذي سنقوم باستخدامه هناك ثلاث خطوات يجب اتخاذها: 
1- استخدام تعبير نظامي يسمح بالتعرف على الجهاز. 
2- تعريف إمكانات الجهاز. 
3- إدخال هذه الإمكانات ضمن ملف الإعداد. 


التعرف على الجهاز 


تعتبر عملية اختبار ترويسة طلب 1١۲۴ 056۲-۸٥۸۲‏ باستخدام تعبير نظامي» الطريقة الأفضل للتعرف على جهاز. 


باستخدام ترويسة ٤1٥ع۲-۸ءء€0‏ الكافية للتمییز بینها. اما إذا كانت قيمة ٤٤ع‏ ۸-إءءلا واحدة لعدة مستعرضات» فيمكننا أولا 
اختبار قيمة ٤1٥ع^-۲إءء0‏ تم قيمة الترويسة ءمراامءءء۸ لتعيين نوع المحتوى الذي يطلبه المستعرض. 


يمكن الوصول إلى الترويسة ٤ءعA-إءءل‏ عن طريق الخاصة اوعںه۸.ءع٠۴ء‏ انام يقوم المثال التالي بكتابة قيمة الترويسة 
:header.log کز¡ڻn yl User-Agent‏ 


<%5@ Import Namespace="System. IO" %> 

<%5@ Page language="c#" 

Inherits="System.Web.UI.MobileControls.MobilePage"$%> 

<%5@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 


<script runat="server" language="C#f"> 
public void Page_Load(object sender, System.EventArgs e) 
1 
FileStream fs = new FileStream (Request.PhysicalApplicationPath 


"header. log", 

FileMode. Append, 

FileAccess.Write); 
StreamWriter log = new StreamWriter (fs); 


//Write the user agent to the log file. 
log.WriteLine (Request. UserAgent) ; 

loo. ETOSR O, 

1 OG CLOSE JF 


} 
I SGI 
<mMOBmM Ke: E OEM AE Eom EUNAE LSER VERLS 
</mobile :Form> 
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بعد إيجاد قيمة الترويسة ۲١ععA-١ءءل‏ لا بد لنا من إنشاء التعبير النظامي ضمن ملف الإعداد. فعلى سبيل المتال» إذا اردنا اختبار 
دعم جهاز معين للمستعرض 82۷۸۴ يمكننا أولاً إخطار النظام بضرورة استعمال قيمة HT P_USER_AGÊNT‏ في عملیة 
الفلترة ثم تحديد الواصفة ١١ء4"‏ للعنصر <ءءهء> كتعبير نظامي كما في الصيغة التالية : 


<browsercaps> 
<use var="HTIP_ USER_AGENT"/> 
€ 1 J. EE > 
Ea Sê Malen = E20:  BZWAE 2.1 Tor EOCkKeG EEL 


</case> 
VE EE 
</browsercaps> 


يمكننا توسيع التعبير النظامي ليشمل رقم النسخة أيضاً والذي يمكن استخدامه لتأهيل الخصائص في غرض :Mobi1leCapabilities‏ 


<case match= 
"EZOS ¬ EzWAP (?'majorVersion'\d+) (?'minorVersion'\.\d+) (\wzZ) " 


ت 


التعرف على إمكانات الجهاز 


يملك غرض كء1اازادمة٣ء!11اهM‏ العديد من الخصائص التي تصف إمكانات الجهاز المحمول. يبين الجدول التالي أهم هذه 
الخصائص و أكثرها استعمالا لهذا الغرض : 
الخاصة النمط القيمة التلقائية الوصف 
Unkown String Browser‏ تعبر عن اسم المستعرض. 

آإuع تأخذ هذه الخاصة القيمة‎ False Boolean CanlInitiate VoiceCall 
إذا كان الجهاز قادر على تأسيس‎ 
أتصالات صوتبة‎ 
تأخذ هذه الخاصة القيمة ٥ںآ إذا‎ Boolean CanSendMail 
كان الجهاز قادر على إرسال‎ 
البريد باستخدام الصيغة اانه"‎ 
تأخذ هذه الخاصة القيمة ٥٣آ إذا‎ Boolean HasBackButton 
کان الجهاز يوفر الزر )ھ8‎ 
متل أكثر الهو اتف المحمولة.‎ 
تحدد نمط الكتابة على الجهاز‎ telephoneKeypad InputType 


اعتماداً على القيم الممكنة للخاصة 
telephoneKeypad‏ 


Î VirtualKeyboard و‎ 
Keyboard 
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IsColor 


IsMobileDevice 


MaximumRenderedPageSize 


MaximumSoftLabelLength 


MobileDeviceManufacturer 


MobileDeviceModel 


NumberOfSoftKeys 


PreferredImageMime 


PreferredRenderingType 


ScreenBitDepth 


ScreenCharactersHeight 


ScreenCharactersWidth 


ScreenPixelsHeight 
ScreenPixelsWidth 


إذا تم تعيين الخصائص السابقة بشكل صحيح ضمن الإعدادات» فسيجري تحميل التطبيقات المحمولة بصورة مقبولة على الجهاز. ولكن 


كيف يمكننا معرفة هذه المعلومات؟ 


هناك عادة ثلاث طرق : 


Boolean 


Boolean 


1- عن طريق الوتائق المرفقة بالجهاز. 
2- عن طريق تطوير برنامج صغير بلغة تأشير يدعمها الجهاز ومحاولة استخلاص قيم هذه الخصائص. 


Unknown 
Unknown 
0 


Image/gif 


Html32 


تأخذ هذه الخاصة القيمة ۲u‏ إذا 
كان الجهاز يدعم الألوان. 
تأخذ هذه الخاصة القيمة ع۲u‏ إذا 


كان الجهاز يدعم عناصر التحكم 
المحمولة. 

الطول الأقصى للصفحة التي 
يمكن إظهارها مقدراً بالبايت. 
الطول الأقصى للنص الذي يمكن 
إظهاره ضمن الزر البرمجي. 
اسم مُصنع الجهاز 

طراز الجهاز 

عدد الأزرار البرمجية التي 
يدعمها الجهاز 

نمط ۴ MIM‏ المفضل الذي 
بإمكان الجهاز إظهاره. 

| النمط المفضل للمحتوى والذي 
يمكن للجهاز إظهاره. تتضمن 
القيم المحتملة , 1132 
wm1l11 ,wm112, chtm110‏ 
تعبر هذه الخاصة عن البعد اللوني 
للإظهار مقدراً ب 1م×ام/)1ط 
الرقم التقريبي لسطور النص الذي 
يمكن للجهاز إظهاره 

الرقم التقريبي للمحارف التي 
يمكن للجهاز إظهارها على سطر 
واحد. 

ارتفاع شاشة الإظهار بالبيكسل. 
عرض شاشة الإظهار بالبيكسل. 
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3- عن طريق تغيير القيم ضمن ملف الإعداد والتأكد من عمل كل منها (الطريقة عادة غير فعالة نظراً لما تستهلك من وقت 
کبیر) 


استخدام لغة تأشير للتعرف على إمكانات الجهاز 


تتلخص الفكرة هنا في محاولة كتابة نص بلغة تأشير مع مراعاة مراقبة دلالات قيم خصائص الغرض ءCap26¡11†)¡e٥Mobile.‏ فإذا 
أخذنا النص التالي المكتوب بلغة اWM‏ : 

<% Response.ContentType= "text/vnd.wap.wml" %> 

<Ixml verSioOn=IL. OS 


<IDOCTYPE uml PUBLIC "=7 /WAPEFORUM/ /DTD WML 1.1//EN™ 
"HEEB: 1 WWW. WaAPEOLUMN.OFO/ DTD WNL 1.1. ml > 


<wml> 
<card id="card1l" title="Card #1" newcontext="true"> 
<do type="accept" label="Softkey label"> 
<go href="F#card2"/> 
€ AOS 
<P align="center"> 
<input type="text" name="test"/> 
Text after input box. 
E. 
<a href="#card2" title="anchor label">Next</a> 
Text after anchor 
Dz 
<J Card 


<Card 1d="card2" tIille="Card F22 
<P align="center"> 
<select> 
<option>One</option> 
<option>Two</option> 
<option>Three</option> 
</select> 
0. 
</ CEES 
</wml> 


يظهر المستعرض 17۷۸۲ النتيجة التالية لهذا النص : 
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[no - title ] 
Text after input box. 
Next Text after anchor 
na - title 


+ Eoftkey Label 7 ا‎ 
Yiew Tools + + 1 E Yiew Tools ۆۆ‎ + f [FÎ | 


نلاحظ من النتيجة أن: 
- المستعرض قام بإظهار سطر بعد حقل الإدخال لكنه لم يُظهر السطر الإضافي بعد الارتباط. 
ڪ تم إظهار علامة خاصة بالعنصر <٥ل>‏ في أسفل الصفحة كزر برمجي وتم استيعاب طول العبارة المخصصة ضمنه لذا. 
- عند الدخول إلى البطاقة الثائية تم إظهار وصلة عند النقر عليها ثم إظهار لاثحة لاختيار. 


من خلال النتائج التي رأيناها يمكننا أن نتوقع القيم التالية لخصائص ies{ځMobileCapabi1i‏ 
الخاصة 
MaximumSoftKeyLabelLength‏ 
RendersBreaksAfterW MLAnchor‏ 
RendersBreaksAfterW MLInput‏ 
RendersW MLDoAcceptsInline‏ 
RendersWMLSelectAsMenuCards‏ 


تحديد إمكانات الجهاز عبر الاختبار 


تحبر عملية فغيير قيمة الخاصة ضمن ملف الإعداذ ومراقبة النتيجة على المستعرض» أحد الطرق التي يمكن اتباعها أيضاً لتحديد 
إمكانات الجهاز. تعتمد هذه الطريقة البسيطة آلية التجربة والخطأ. 


سنقوم في مثال بسيط بتحديد إمكانات الجهاز عن طريق الاختبار. ففي النص االبرمجي التالي سنختبر قيم للخصائص: 
RenderBreakAfterW MLAnchor‏ 
.RenderBreaksAfterWMLInput‏ 


لنتمكن من القيام بهذا لا بد أن نبدأً من ملف إعداد يوفر الحد الأدنى من التفاصيل للتعرف على الجهاز ثم نقوم بتجربة الخرج: 
<browserCaps>‏ 
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<uSse var="HTIP_USER_AGENT" /> 


CET MEC 
<case 
MEE CE 


"EZOS = EZWAP (ma jorVerslonNn QAF) (FF minorVersion(. OFFI OWT 


h previously established properties -=-> 


> 


ES EAE WE 


browser="EzWAP" 


type="EzWAP" 


version= ${majorVersion}.${minorVersion } 


= ${majorVersion} 
SIMAR OE Mer SA OM |} 

Ge="tFUe™ 

Model="Pocket PC" 

deringType="wml12" 

deringMIME="text/vnd.wap.wml" 
geMIME="image/vnd.wap.wbmp" 


majorVersion 
minorVersion 
i1isMobileDevi 
mobi le De vi Ce 


ج 


preferredRen 
= 


preferredRen 
preferredIma 


inputType="virtualKeyboard™ 


<!Test with default values Tor These Groperlties FITS =. 


sAfterWMLAnchor="false"™ 
sAfterWMLInput="false" 


mobile" 
E UN MOA N eECORE SONS 


rendersBreak 
rendersBreak 
</case> 
</filter> 
</browserCaps> 


Register TagPrefix=" 
Namespace="System.We 


Assembly="System.Web.Mobile" %> 


odebehind="Mobi leWebForm1.apsx.cs" 
bWeb.TestBrowserCapabilities.MobileWebForm1" 
Sel. 


UMA E =1 SEE VERY 
TextBoxl" runat="server" /> 
SALLY EUMEE=E SCEMOR HS 


KI tuna = Ser VEEL > 


OeOLZAY UME = SEK VOR > 


Page language="c#" C 
Inherits="MSPress.Mo 
AutoEventWireup="fal 


MOONE SEOEM ME LEO 
MOON NE MESES OL 
<M lle:Label id="La 

Af Ee UMSUE 

</ ile: Label 

<m Me SANK MOLT 


</ ile LIRK 
<mMobi le Label 1da 
Text After Link 
</mobile:Label> 
VIMO le E OEMS 


بمراقبة الخرج الخاص بنموذج الوب المحمول الذي قمنا بإنشاءه» نلاحظ وجود سطر إضافي بعد حقل إدخال النص وعندها يمكننا أن 
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.false yl RendersBreaksAfterWMLInput ةصlاخلl‎ jييعت نعرف أنه يجب‎ 


بمتل هذه الطريقة يمكن تعيين الكثير من قيم الخصائص ولكن كما نلاحظ فإن هذه الطريقة لا تتطلب معرفة بلغات التأشير المختلفة 


لكنها تستهلك وقتا أطول. 
CE Remote Display : Fal E‏ 
Fil #Znom Tools Help‏ 


8 E208 EzZWAP 14:05 
* Îhttp:/132.,158.0.1deviceconfig ¥” 


[na - title ] 


Text after Input 
Link 
Text after Link 


ر 
Yîiew Tools + +: FY a |‏ 


ضبط موائمات الأجهزة 


الجهاز عند ورود طلب ما وسوف نتعلم كيف نقوم بتوسيع المجموعة الخاصة بموائم الجهاز لدعم جهاز جديد أولغة تأشير جديدة. 


cHIML 
adapter 


HTML 


adapter 
MiobileControl 


class 
WML 
adapter 


\lserdefined 
adapter 
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بعد أن يقوم المحرك زمن التشغيل بالتعرف بنجاح على الجهاز ويجري تأهيل خصائص الغرض كع1:)1اaمa٣eاMobi‏ لا بد من 
تحديد لغة التأشير الأنسب للجهاز مرسل الطلب. 

تعتبر موائمات الأجهزة الجزء من عناصر التحكم المحمولة الذي يقوم بتقديم عناصر التحكم المحمولة بالشكل المناسب على جهاز 
لذا يجب النظر إلى صفوف موائمات الأجهزة (مجموعاتها) على أنها جسر بين عنصر التحكم المجرد والزبون كما يظهر الشكل التالي. 


صفحة نموذج الوب المحمول 


E NC er ETE 


تدعم عناصر التحكم المحمولة في ۸A5S۲.N٤1‏ مجموعة واسعة من الزبائن تشمل , WML1.1‏ 
XHTML‏ ,1.2,cHTML|1.0,HTML.32اM‏ ۷ . تقدم الموائمات المتوفرة نتائج جيدة على معظم التجهيزات المتوفرة. تم توفير 
النص المصدري لموائمات الأجهزة لتشجيع المطورين على خلق موائمات جديدة للأجهزة غير المدعومة. يمكن الوصول إلى النص 
المصدري عن طريق الوصلة «http://go.microsoft.com/fwlink/? LinkId=6350‏ 


. 


استخدام مجموعات ضبط الموائمات الخاصة بالأجهز 


يمكننا تعريف العلاقة بين موائمات الأجهزة وعناصر تحكم نماذج الوب المحمول ضمن Web.config‏ İوmachine.config‏ وذلك 


فعلى سبيل المثال تم تزويد عناصر التحكم المحمولة في ٤٥.مء۸‏ بثلاث أنماط من موائمات التجهيزات المسبقة التعريف كعناصر من 
Jl.لزک <ChtmlDeviceAdapter> «<<WmlDeviceAdapters> «<HtmlDevice Adapters> رصlizss machine.config‏ 
كما تمت إضlفة‏ ڏpe .<XHTMLDeviceAdapters>‏ 


تقوم كل مجموعة موائمات أجهزة بمقابلة كل عنصر تحكم محمول بموائم الجهاز المناسب والذي يقوم بتصيير التأشيرات المناسبة إلى 
الزبون. عند تلقي طلب من الزبون»ء يجري إسناد موائم أوأكثر إلى هذا الطلب والذي سيقوم بدور تخديم هذا الطلب. 


يجب تعيين مجمو عة موائمات الأجهزة ضمن العنصر <۲01 Web.config jaض <mobileC‌on‏ İوmachine.config‏ حیث يدعم 
هذا العنصر عة عناصر مشتقة من العنصر <device>‏ المستخدم لتعريف مجمو عات موائمات الأجهزة. 
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يظهر الجدول التالي خمس واصفات يدعمها العنصر <عع¡۷عل>: 

الواصفة الوصف 

name‏ اسم مجموعة الموائمات 

predicateClass‏ اسم الصف الذي يحتوي طريقة الإسناد 
predicateMethod‏ اسم طريقة الاسناد لمجموعة الموائمات. وهي عبارة 
عن طريقة ساكنة يجري استخدامها للتأكد فيما إذا كانت 


مجموعة موائمات الأجهزة مناسبة للجهاز الزبون 
الحالي. 

pageAdapter‏ اسم صف موائم الصفحة الذي يقابل مجموعة 
الموائمات. 

inheritsFrom‏ يمكن استخدامها لوراثة الإعدادات من مجموعة 


موائمات أجهزة أخرى. 


يدعم العنصر <ءء۷1عل> مجموعة عناصر أبناء من النوع <اهءأ«هء> والتي تستخدم في إسناد عنصر تحكم محمول إلى موائم 
عنصر تحكم. فعلى سبيل المثال يمكننا إسناد عنصر التحكم المحمول ۴2,٤1‏ إلى موائم عنصر llتھكp .WMLPane1Adapter‏ 


يملك عنصر <[١۲٤«0ء>‏ واصفتين هما ع11۳ و١عامةله.‏ يتم إسناد اسم صف عنصر التحكم المحمول إلى الواصفة ع14۳ وإسم 


GN WEE SALON OY EEOC NEE UUEE Mz 
< EOE 1 CE E LOE 
<system.web> 


€ >= OES WES. COME LG SEE LNEGS > 


<mobileControls> 
<device 

name="HtmlDeviceAdapters" 

predicateClass= 
"System.Web.UI.MobileControls.Adapters.HtmlPageAdapter" 

pEedi CateMet hod=lDeva cCeOUua lif ies 

pageAdapter= 
"System.Web.UI.MobileControls.Adapters.HtmlPageAdapter"> 


<control name="System.Web.UI.MobileControls.Panel" adapter= 
"System.Web.UI.MobileControls.Adapters.HtmlPanelAdapter"/> 


<control name="System.Web.UI.MobileControls.Form" adapter= 
"System.Web.UI.MobileControls.Adapters.HtmlFormAdapter"/> 


SI AIA DEeE MeaPpPiInNSIS CORNER 2> 


</device> 
</mobileControls> 
</system.web> 
<€ HECE 1ej el ORE 
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تعريف مجموعة موائمات أجهزة 


ذكرنا أنه يمكن لنا كتابة صفوف موائمات جديدة لعدة أسباب. فمثلاً يمكننا استبدال موائم جهاز قياسي بنسخة مخصصة أويمكن إضافة 


مو ائمات أجهزة لدعم عناصر تحکم مخصصة. 


تحديث تعريفات مجموعة موائمات التجهيزات ضمن ملف عاگمص0ء.ع«1طعهص. وذلك باستبدال اسم الصف الخاص بموائم الجهاز 
تالضف قال اة نة 


كحل بديل يمكن أيضاً تعريف مجموعة موائمات أجهزة ترث جميع الإعدادات من مجموعة موائمات باستخدام الواصفة 


inheritsFrom‏ لعنصر <ءvicعd>.‏ إذ یتم تعريف عناصر أبناء <اcon)0>‏ ضمن العنصر عءء۷1ء[ لتستبدل تلك التي تملك نفس 
الاسم في مجموعة الموائمات الآباء. كما يمكن تعريف عناصر <1١1۲١0ء>‏ خاصة بعناصر التحكم المخصصة. 


يبين المتال التالي الإعدادات الخاصة بوراثة مجموعة موائمات أجهزة كإعامة4dعء¡‏ م۷12 وتحديد طربقة اسناد باسم 
:DeviceQualifies‏ 
xml verSIORLN O! CNEOGINIS LUE OLS‏ 


eo O 
<system.web> 


<!=— Other Web.COnfig Settings==-> 


<mMODI1leCoONEEOlS> 
<device 
name="NewWmlDeviceAdapters" 
inheritsFrom="WmlDeviceAdapters"™ 
predicateClass= 


"System.Web.UI.MobileControls.Adapters.WmlPageAdapter"™ 
predicateMethod="DeviceQualifies" 
pageAdapter= 


"System.Web.UI.MobileControls.Adapters.WmLlIPageAdapter"> 
EOE EO 


name="System.Web.UI.MobileControls.MyControl"™ 
adapter= 


"System.Web.UI.MobileControls.Adapters.WmlMyControlAdapter"/> 


<!-= Place any hew mappings here =z 


</device> 
<mMmOO1ILECONErOLS> 
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أما النص البرمجي الخاص بطريقة الاسناد فيكون: 
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القسم الرابع عشر: 
برمجة موائمات الأجهزة وإنشاء العناصر المخصصة من الصفر 


الكلمات المفتاحية: 


عنصر تحکم»› موائم» جهاز» ملف الإعدادء عنصر مخصص . 


ملخضص: 
سنتعرف في هذه الجلسة على دورة حياة عنصر التحكم المحمول وكيفية برمجة صفوف مو ائمات الأجهزة لتطبيق المنطق الخاص بكل 
ا 


أهداف تعليمية: 
يتعرف الطالب في هذا الفصل على: 
€ دورة حياة عنصر التحكم والمراحل التي يمر بها 
دوز مراسات الأجهزة 
© كان التصوص المضدرية لمرائمات الأجهزة 
© بناء عنصر تحكم من الصفر وبناء موائمات الأجهزة المخصصة له 


€ ضبط وتعريف موائمات الأجهزة 


© دعم التقسيم إلى صفحات والربط بقواعد البيانات لعناصر التحكم المخصصة. 
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برمجة موائمات الأجهزة وبناء عناصر التحكم 


سنتعرف في هذه الجلسة على دورة حياة عنصر التحكم المحمول وكيفية برمجة صفوف مو ائمات الأجهزة لتطبيق المنطق الخاص بكل 
ا 
سنستعر ض كذلك كيفية بناءِ عناصر التحكم بوراثة الصف MobileControl‏ وكيفية تطبیق صفوف الموائمات عليه لیتم إظهاره على 


بناء عناصر التحكم من الصفر: 
ا تيت ضفن فاص ااك رة المر رة ما بلي عا دافا تفر ير تصن تكد مرل مق الضقر ركلك اقا حف 
يرث الصف 1٥n†rهMobileC‏ أو أي صف قاعدي nٽJ .Panel yi PageControl‏ 
يتطلب تطوير عناصر التحكم من الصفر حجم عمل أكبر من عملية إنشاء عناصر التحكم بالتركيب أوبالوراثة. 
فعند تطوير عنصر تحكم اعتمادا على عنصر آخر موجود» فقو قط بتعديل تصرفات عتصر التحكم الحالي عبر إضافة 
خاصة أوطريقة جديدة أوإعادة تعريف خصائص أوطرق موجودة. 
كذلك هي الحال عند تركيب غتصر تحكم باستخدام عدة خنصر تحكم من العفاصر المتوفرة إذ لاتكون عملية التطوير معقدة 
أبداً وذلك بسبب وراثة جميع وظائف عناصر التحكم المُستخدمة. 
أما في حالة تطوير عنصر تحكم من الصفر فلايتوجب علينا فقط تطوير الصف الخاص بعنصر التحكم» وإنما تطوير صف أوصفوف 
موائمات الأجهزة لعنصر التحكم الجديد هذا. 
قبل الشروع بكتابة عناصر التحكم لا بد لنا من فهم المراحل التي يمر بها عنصر التحكم والطرق التي يقوم باستدعاءها وأوقات 
استدعائها. 


يمكن تلخيص هذه المراحل كما يلي : 
1- تحميل محتوى الصفحة وبناء عناصر التحكم. 
استعادة حالة عناصر التحكم إذا كان قد جرى حفظ أي قيم سابقة في نهاية الطلب السابق للتطبيق. 
معالجة البيانات التي تم إرسالها من الزبون وتحديث حالة عنصر التحكم. 
إطلاق أحداث المخدم وتنفيذ معالجات الأحداث. 
حفظ حالة عنصر التحكم بانتظار الطلب التالي. 
تشكيل جواب وإرساله إلى الزبون. 
التخلص من الصفحة وعناصر التحكم واستعادة الذاكرة المخصصة لها. 


ذكرنا أيضاً أن إطار عمل يقوم باستدعاء مجموعة من الطرق التي تقوم باستبدال أوتطبيق الوظائف المخصصة المراد الوصول إليها. 
يوضح الجدول التالي دورة حياة عنصر التحكم والطرق والأحداث التي يجري استدعاؤها: 

المرحلة ماذا يحدت الطرق أوالأحداث التي يتم تنفيذها طرق موائمات الأجهزة 
التأهيل یتم تأهیل الإعدادات | )iہ0,1: :Onlnit‏ 
اللازمة للطلب تقوم الطريقة ٤«آم0‏ بإطلاق الحدث نم1 _ يتم اختيار صف موائم الجهاز المناسب 
الحالي وتقوم باستدعاء الطريقة ٤١آ"‏ التابعة عند خلق مثل من عنصر التحكم. إذ تقوم 
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TE 
ViewState 


إرسال البيانات 


من الزبون 


jaViewState 
الغرض المخزن في‎ 
نهاية الطلب السابق.‎ 


یتم تحليل البيانات 
المرسلة من الزبون 


تجري هنا الأعمال 
التي يجب أن تظهر 
عند کل طلب» کفتح 
اتصال بقاعدة 
البيانات مثلا. 


یتم إطلاق أحداث 
التغيير عند الحاجةء 
أي في حال غيرت 
البيانات المرسلة من 
بيانات الحالة 
الخاصة بعنصر 


التحكم. 


لصف موائم الجهاز. 

إعادة تعريف تلك الطريقة. 
:LoadViewState‏ 

يجب أن نقوم بإعادة تعريف 

iewtt6‏ 0¥[ في حال رغبنا 
بتخصيص عملية استعادة الحالة. 

إذ تقوم الطريقة 

ad Private View State‏ ابتحميل الحالة 
الداخلية التي تم إرسالها إلى المستخدم. 


:LoadPostData 
يتم إرسال نتيجة تفاعل المستخدم مع عنصر‎ 
التحكم إلى المخدم كجزء من الطلب الحالي.‎ 

يتم تحليل البيانات المرسلة وتحديث 
الخصائص المناسبة لهذا العنصر. 

لا تشكل العناصر التي لا تتبنى الصف 
IPostBackDataHandler‏ جا من هذه 
المرحلة. 

:OnLoad 

تقوم هذه الطريقة بإطلاق الحدث 1044 
واستدعاء الطريقة 0٣1024‏ ضمن صف 
موائم الجهاز. في نهاية هذه الطريقة يكون 
عنصر التحكم مبني بصورة كاملةء وتطبح 
استعادة الحالة نتيجة من نتائج مرحلة إعادة 
إرسال المعلومات» كما تجري عملية 
استعادة البيانات من قواعد البيانات. 
:RaisePostDataChangeEvent‏ 
يجري إطلاق أحداث التغيير إذا تغيرت 
بيانات الحالة بين عملية الإرسال السابقة 
والحاليةء كما هي الحال عندما يكون الحدث 
rext changed‏ الخاص بعنصر التحكم 
٦×8 0×‏ أحد هذه الأحداث. 


لا تشترك عناصر التحكم التي لا تدعم 


الطريقة اiدآ[م0‏ ضمن الصف 
MobileContro1‏ باستدعاء الطريقة 
11 ضمن صف موائم الجهاز. 
:LoadAdapterState‏ 

إذا كان موائم الجهاز يحفظ أي معلومات 
خاصة بالجهاز ضمن عwW5)2ع۷1»‏ 
يجري تحميل هذه المعلومات في هذه 
الفز اة 

تقوم lلÙطريقة LoadPrivate View State‏ 
الخاصة بالصف MobileContr0|‏ 
باستدعاء هذه الطريقة 
(LoadAdapterState)‏ 


بشكل تلقائي لا تشترك أي طرق تابعة 
لصف موائم جهاز في هذه المرحلة. 


:OnLoad 

تقوم هذه الطريقة الخاصة بالصف 
MobileContro1‏ باستدعاء الطريقة 
L4‏ الخاصة بصف موائم الجهاز. 


بصورة تلقائيةء لا تشترك طرق صفوف 
موا خا کی د ا 


Universal Knowledge Solutions s.a.1 


242 


معالجة أحداث 
إرسال البيانات 


الأحداث التي 


تستجيب من طرف 
المستخدم والناتجة 
عن عملية التفاعل 


مع الزبون. 


يتم في هذه المرحلة 
حفظ معلومات 
الخاصة 

View tate‏ ضمن 
غرض من نمط 
سلسلة نصية ليتم 


]PostBackDataHandler‏ في هذه 
المرحلة. 

:RaisePostBackEvent 

ينطلق هذا الحدث بعد أي حدت تغيير. 
يجري إطلاق ما يسمى حدث من جهة 
الزبون باتجاه المخدم. فعلى سبيل المثال 
Command‏ محمول تتم عملية إرسال 
المعطيات ويجري إطلاق الحدث ع1ا€. 
لا تشترك العناصر التي لاتتبنى الصف 
]PostBackEventHandler‏ في هذە 
المرحلة. 

:OnPreRender 

تقوم الطريقة on Pr eR ende‏ بإطلاق 
الحدث إعلdمء‏ ۸ء۴ واستدعاء الطريقة 
0nPreRender‏ ضمن صف موائم 
الجهاز. 

كما تتم في هذه المرحلة أي تحديثات 
إضافية على معلومات الحالة لعنصر 
التحكم. 

عادة ما يكون الوضع الأصلي للطريقة 
SaveViewState‏ ا في معظم 
الحالات. 

على أي حال يمكن إعادة تعريف الطريقة 
eV İiew tate‏ عند الرغبة في 
تخصيص إدارة الحالة. 

تستد عي الزطريãة Save ViewState‏ 
الطريقة SavePriva ie ۷1ew Se‏ والتي 
تقوم بتخزين معلومات الحالة الداخلية التي 
تمت إعادة إرسالها إلى الزبون. 

بسبب محدودية عرض الحزمة في الحلول 
المحمولة يجري تخزين عاw5)a‏ ع۷1 
ضمن غرض جلسة على المخدم كما شرحنا 
في جلسات سابقة. 

على أي حال» يمكن للمطور إلغاء تفعيل 


:HandlePagePostBackEvent 
إذا أمكن للأحداث المرسلة إلى عنصر‎ 
التحكم أن تتنوع اعتماداً على الجهاز‎ 
الهدف» فيجب على عنصر التحكم في هذه‎ 
الحالة استدعاء‎ 
sءlطþbe!‎ HandelPagePostBackEvent 
موائم الجهاز الفرصة لمعالجة حدث إرسال‎ 
البيانات.‎ 


تقوم الطريقة إعءل”e‏ ۸م0۸۴ في الصف 
MobileContro1‏ باستدعاء الطريقة 
0nPreRender‏ ضمن صف موائم 


الجهاز. 


:SaveAdapterState 
يمكن لغرض موائم الجهاز حفظ أي‎ 
معلومات عاه)wWSع ۷1 خاصة بالجهاز‎ 

باستخدام هذه الطريقة. 
حيث تقوم الطريقة 
SavePrivateViewState‏ الخاصة 


بالصف ۲01) 01٤ء011‏ Mباستدعاءِ‏ هذہ 
الطريقة. 
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.ViewState 
مختلفة حیث‎ Private ۷1ew 5)2 تکون‎ 
يتم إرسالها إلى الزبون ولايمكن إلغاء‎ 


في هذه المرحلة :Render Render‏ 

2 : تو ذه الطريقة باستدعاء الطريقة E‏ : 
سيتم توليد الخرج E‏ . و الطوي تستخدم هذه الطريقة الغرض 
الذي سیتم ارا ۲٤۵٥ء۸‏ الخاصة بصف موائم لجاز مز ۲٥× W‏ e]زطهN‏ لتقوم بإخراج 
إلى الزبون. التأشيرات المطلوبة لعنصر التحكم على 
الجهاز الزبون. 
في هذه المرحلة يقوم :OnUnLoad OnUnload‏ 

نص الته> تقوم الطريقة ١۵٥1م‏ لم0 بإطلاق الحدث 


رو کد 4ا وتقوم باستدعاء الطريقة 

الاه €n‏ الخاصة بصف موائم الجهاز. 
يجب أن تحرر هذه المرحلة الموارد المكلفة 
مثل الاتصالات التي جرى تأسيسها مع 
قاعدة البيانات. 

Dispose 


تقوم الطريقة 24٥1م‏ ل٣0‏ في صف 
MobileContro1‏ باستدعاء الطريقة 
n4‏ في صف موائم الجهاز. 


دور موائمات الأجهزة 


توسع تقنية ۸8۴.٤1‏ المحمولة تقنيات ۸8۴.٤1‏ الأخرى. وهي تعمل بنفس الطريقة وتستخدم مجموعة متشابهة من الطرق 
والتصرفات كون هذه العناصر كلها ترث من الصف 1١٥إ٤”٥٣.01.ءm«.۷عاءرS.‏ إلا أن إحدى الاختلافات الجوهرية بين عناصر 
التحكم المحمولة وتلك القياسية تكمن في استخدام عناصر التحكم المحمولة لموائمات الأجهزة. 


إن أحد أول الطرق التي سنقوم بكتابتها عند تطوير عنصر تحكم مخصص في ۸5۴.٤١‏ هي الطريقة هل١۸‏ والتي تقوم بتشكيل 
الخرج بصيغة لغة تأشير والذي سيتم إرساله إلى المستخدم. 


يمتلك عنصر التحكم امول ضا الطريقة إعلرعR؛‏ إلا أنها لا تقوم بتشكيل خرج بل تقوم باستدعاء الطريقة إعلدءR‏ المرتبطة 
بغرض موائم الجهاز والذي يقوم بدوره بتشكيل الخرج بلغة التأشير المناسبة. 
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يحتاج كل عنصر تحكم محمول عادة إلى صف أوأكثر من صفوف موائمات الأجهزة حيث يوفر كل صف إمكانية العمل على نمط 


معين من الأجهزة. 


يعبر الشكل التالي مثلاً عن التفاعل بين عنصر التحكم المحمول ا115 وصفوف الموائمات المرتبطة به. 


HtmiListAdapter 
device adapter class 


cHtmlListAdapter 
device adapter class 
List çonirg] |, E 2 
device adapter class 


xXyzL istAdapterf 
custom dêvicê adapþtêr | 


عندما يصل طلب مستخدم ما إلى المخدم» يجري التعرف على نوع الزبون بفحص السلسلة المحرفية ۸۲٥٤ع‏ ۸^-١ءءل‏ الممررة عن 

طريق ترويسة طلب 1١۲۴‏ كما رأينا في جلسة سابقة. ثم يتم البحث عن الجهاز ضمن لاثحة التجهيزات المدعومةء ومن ثم يتم 

تخصيص مجمو عة موائمات الأجهز ة المناسبة لهذا الطلب. 

تحتوي مجموعة موائمات الأجهزة» صف موائم جهاز خاص بكل عنصر تحكم محمول. تشترك جميع صفوف موائمات الأجهزة في 
مجموعة واحدة من حيث دعمها لنفس النمط من جھاز الزبون مٿل .XHTMLyÎ CHTML «HTML3.2 «WML1.1‏ 
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عند تطوير عناصر التحكم المحمولة الجديدة يجب تطوير موائمات أجهزة لكل نمط من الأجهزة المراد دعمها وإضافتها ضمن مجموعة 
الموائمات الخاصة بها. 


المختارة لتوليد التأشيرات التي سيجري إرسالها إلى الزبون. 
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List control HtmlListAdapter 


this,.Adapter E 


Command HtmlCommandAdapter 
control 


Selected device 
adapter set 
TextBox HtmIfextboxAdapter 
control 


xyz ontrol 


بنيان دعم الأجهزة القابل للتوسع 


إن بنيان دعم الأجهزة في 48۴.٤1‏ قابل للتوسع. لذلك فإن عملية تحديث عناصر تحكم ۸8۲.٤1‏ المحمولة سيؤدي إلى دعم 
أنواع جديدة من التجهيزات. وحتى إذا كتا لا نريد انتظار التحديث من ا؟هوهإء1 وكان الموائم التلقائي الذي يجري إسناده إلى الجهاز 


العمل مع النصوص المصدرية لموائمات الأجهزة: 

إن استخدام بيئة التطوير 0.6نلداء 21ء۷1 هي الطريقة الأكثر سهولة لتطوير موائمات الأجهزة. إذ يمكننا إضافة النص البرمجي 
لموائم الجهاز الذي قامت M1۴‏ بتقديمه إلى مشروع ما من الرابط http://go.microsoft.com/fwlink/?Link1Id=6350‏ 
لتسهيل عملية التطوير. يمكن بعدها تحويل النص البرمجي إلى الصيغة المطلوبة ووضعه على مخدم الوب واستخدامه ضمن التطبيقات. 


نورد في ما يلي المراحل التي يمكننا اتباعها لعملية التطوير: 
إنشاء مشروع جديد بلغة ٣#‏ (أو gill j (VB‏ ع Class Library‏ تحت wlم‏ lلnشرg‏ ع Custom Adapters‏ 
حذف الصف التلقائي وء.1ءءه1ح الذي قام 0زلناء 1مسء۷1 بإنشاءه ثم النقر بالزر الأيمن فوق المشروع في نافذة S110٣‏ 
Explorer‏ واختیار ۸d‏ تم Ad Existing 1em‏ تم إضافة جميع نصوص KC‏ البرمجية التي تم تحمليها من موقع 
Micros‏ والخاصة بموائم الجهاز. 
النقر بالزر الأیمن ضمن liفذةö .Add Reference رlıتخlg Solution Explorer‏ 
ف„ )System. Web.Mobile.d11) .Mobile Internet Control Runtime رڙlتخl NET. Û)‏ بالإضافة إلى مکونات 
System.Web. 11‏ لضمها إلى المشروع. 
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5- يكون النص المصدري لموائمات الأجهزة هونفسه المستخدم لمعالجة موائمات الأجهزة المعرفة في فضاء الأسماء 
System. Web. U 1.MobileControls. Adapter‏ حیٹث تستخدم هذه النصوص نفس أسماء الصفوف. فإذا قمنا بعملية تجميع 
لملف يحتوي هذه النصوص وحاولنا استخدامه ستظهر رسالة خطأً لأن محرك زمن التشغيل لن يكون قادرا على التمييز بين 
الصف Web. 1.Mobile. Adapters. Html From Adapter‏ .temرSys‏ والصف ضمن ملفنا التجميعي والذي يملك نفس الاسم 
ويتوضع ضمن نفس فضاء الأسماء. 
لحسن الحظ تستخدم النصوص المصدرية تستخدم عملية التجميع الشرطي لتعريف فضاء الأسماء الذي تنتمي إليه الصفوف. فإذا 
قام التطبيق بتعريف llثlبٽت C0MPILING_FOR_SHIPPED_SOURCE‏ يجري تلقائياً تعريف مصادر موائم الجهاز 
؛ضja .System.Web.UI.MobileControls.Shipped AdapterSource‏ 
في بيئة Stdi0.NE81‏ u21ءVi‏ يمكن تعريف هذا الثابت بالنقر بالزر الأيمن على المشرو ع ضمن liفذة Solution Explorer‏ 
واختیار ٤ع‏ 1م‌م٥إ۴»‏ واختیار مجلد 8ع Configuration Prope)‏ ضمن شجرة المجلدات في يسر صفحة الخصائص. ومن تم 
اختيار الخيار 14¡ 8ء و أخيراً إڊإخاJ COMMPILING_FOR_SHIPPED_SOURCE‏ بعد أي ثابت من الثوابت 
الموجودة ضمن المساحة المخصصة لثوابت التجميع الشرطي. 
يجري إنشاء أي موائم جهاز جديد لعنصر التحكم المخصص وتعديل النص المصدري لعناصر التحكم الموجودة. ثم تجميع 
المشروع للحصول على ملف تجميعي جديد يحتوي كل موائمات الأجهزة. 
لاستخدام الملف التجميعي الجديد يجب إنشاء مشروع وب محمول جديد» تم النقر بالزر الأيمن على المشروع ضمن نافذة 
Explorer‏ utionا0‏ واختيار A44 Reference‏ ثم اختيار المكتبة الحاوية على موائم الجهاز المخصص (0511) وإضافتها 
إلى المشروع. سنحتاج أيضاً إلى ضبط إعدادات المشروع لاستخدام الموائمات المخصصة وذلك من ضمن الملف عاfر0ء.ا۷6‏ 
الخاص بالتطبيق. 


بناء عنصر تحكم مخصص بسيط وبناء موائم جهاز 


سنقوم في هذا الجزء من الجلسة ببناء عنصر تحكم شبيه بعنصر تحكم القائمة إضافة إلى إنشاء موائم جهاز لهذا العنصر. 


بشكل تلقائي يتم إظهار عنصر التحكم هذا كجدول في الأجهزة التي تدعم ا11۷1 وكلائحة من الارتباطات في الأجهزة التي تدعم 
.WML‏ 


يكون عنصر التحكم الذي نبنيه عبارة عن عنصر تحكم جدول يتم إظهاره كجدول بعمودين على الأجهزة التي تدعم HM‏ 
.WMLg‏ 


فيما يلي النص البرمجي لعنصر التحكم وهويساعد المستخدم في تحديد خاصة العنوان ء1٤11‏ إضافة إلى خاصتين تمتلان العناصر 
ضمن العمودين في صف واحد. 
using System;‏ 


USING SYSTEM. Web. UL MODILECONEEOLS? 


namespace MSPress.MobWeb.CustomControls 


{ 


/// <summary> 
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f14 Simlo Cxemole OC 34 CUSLOM CONLEOL Ou1ilt EEO SCEILCA 
/// </summary> 
BUGLE ClaSS CEMALE E MOBIlECONEEOL 
{ 
private String _title, _item1Text, _item2Text; 
public CMTable() 
{ 
Title > TY; 
Iteml1lText = 
Item2Text = 


<summary> 
Gets and sets the text that 
can be displayed as a title 
</summary> 
pPUSIIE SEITING Tile 
1 


get { return _title; } 
set {_title = value; } 


} 


/// <summary> 
/// Gets and sets the text displayed in column 1 
/// </summary> 
puglic String IiemlText 
1 
get { return _itemlText; } 
SEE {TEC TOE = WaAlMOF J 
} 
/// <summary> 
/// Gets and sets the text displayed in column 2 
/// </summary> 
puUGlic Siring ITiem.TEezxt 
1 
get { return _item2Text; } 
SEE { _MECMZNEE = WAU | 


CustomMobileLibrary‏ مثلا. لنقوم بعدها بإضافة مرجع إلى الملف التجميعي الخاص بزمن التشغيل لعناصر التحكم المحمولة 
)System. Web.Mobile.d11)‏ كذلك ۷.411 .nعاءر؟‏ تم إضافة ملف صف إلى المشروع والذي يحتوي النص المصدري السابق 


وأخيرا نقوم بتجميع الملف. 


بعدها يجب إنشاء صفوف موائمات الأجهزة التي تحوي منطق الإظهار. ففي حالتتا يلزم صفان الأول مخصص ل 1M‏ 
و HTML‏ والثاني مخصص WML J‏ 
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using System; 

USING SYS EM. WED. UL WMODIlECoN TOLLS, 

using System.Web.UI.MobileControls.Adapters; 
using MSPrEss .MODWEBD.CUSiOMCONEFOLS ; 


namespace MSPress.MobWeb. CustomControls. Adapters 
{ 
public class HtmlCMTableAdapter : HtmlControlAdapter 
1 
protected new CMTable Control 
{ 
GEE 
{ 
BE EUAN (COMuablEeE Base CODE O LL, 


} 


public override void Render (HtmlMobileTextWriter writer) 
{ 

SETINGg Cable UTI = WY, 

Alignment alignment = 

(Alignment) Style [Style.AlignmentKey, true]; 
if (alignment != Alignment.NotSet && alignment != 
Alignment.Left) 

{ 


WE Ee MEA Ee ( LCG al OM LL), 
writer.Write(alignment.ToString()); 
writer.WriteLine ("\">"); 
Eable SUE EIS LOE MVS 


e ACE E E LONE e (U wLClE AA, FOOSE 

AISA EEN OUEE (CE LPAI, LOL, 
.RenderBeginTag ("table"); 
.Writeline(""); 

WEEE LSE CEA > O), 
.ENEeEEOEMaAE (SEY Le), 
.WriteEncodedText (Control. Item1Text) ; 
.ExXiEEOEMa E (SE YL), 

WEN EeLA Me LCE). 

.Write ("<td>"); 

-ENtEerE OEMaAE (SEVE), 
.WriteEncodedText (Control. Item2Text) ; 
.ExiEEOEMaAE (SEVE J, 

Wei Eee ( CVE EEL). 
.RenderEndTag(); 

.WritelLine (tableSuffix); 
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using System; 

USING SYST EM. WED. UL. Mobi leCoNTroOlS; 

using System.Web.UI.MobileControls.Adapters; 
using MSPrEEss . MOWED. CUSTOMCONEFOLS ; 


namespace MSPress.MobWeb. CustomControls. Adapters 
{ 
public class WmlCMTableAdapter : WmlControlAdapter 
1 
protected new CMTable Control 
{ 
GEE 
{ 
Fe UE (CMuable) Kase. CODE OL, 


1 


public override void Render (WmlMobileTextWriter writer) 


{ 


Alignment alignment = 
(Alignment) Style [Style.AlignmentKey, true]; 
SEIN altonNID; 

switch (alignment) 


{ 


case Alignment .Center: 
alionID <S 
break; 
Case Alignment. Right: 
alionIiD = 


//Write beginning of table 
writer.EnterLayout (Style) ; 
writer.EnterFormat (Style); 
writer.RenderText ("<table", false, false); 
TE (COMEEOL MIELE. LENGER > 0) 

WEA ECER WETECENEEEIBUEE(LEIElLE, CONEEOL DIE 
WEA EEE WEN ECAEEEIOUEE (al GR LL, alIONID 4 a 
EEE WME NECA EEEN BUEEe ( LOCO UMASS NS 
writer.WriteLine (">"); 


//First datacell 

WEN EEE WEI EE) SER > GES > J; 
writer.RenderText (Control. Item1Text, true); 
writer.RenderText ("</td><td>", false, false); 
//Ssecondl Catace ll 
writer.RenderText (Control. Item2Text, true); 
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writer. RenderText ("</td></tr>", false, false); 
writer.WriteLine ("</table>"); 


//close table and output a trailing break 
MEI Ee. H< EEOEMaA E (SEYVLe ) 
writer.ExitLayout (Style, true); 


يجب تجميع هذه الصفوف ضمن ملف تجميعي بنذ الطريقة التي اتبعناها مع عنصر التحكم. يمكننا وضع هذه الصفوف ضمن ملفاتها 


كتابة لغة التأشير الخاصة بالجهاز باستخدام صفوف Mobile extW rier‏ 


يفوخ إطار العمل الخاص :بالصفكة ‏ باستدغاء . الطريقة إ6فذةR ٠‏ ممررا كمغامل ‏ صف بيتحدز من الصق 
Wm]MobileTextWriter gy System. Web.UI.MobileControls. Adapters. Mobile Text Writer‏ بالنسبة للموائم الذي 
یرٹ Wm[Contro1Adapter ja‏ « و Htm]MobileTextWriter‏ بالنسبة للموائم الذي يرث من نص .HtmlContro1Adapter‏ 
تستخدم هذه الصفوف لإرسال الخرج بلغة التأشير إلى الزبون. 


تمتلك الصفوف المتحدرة من ۲ءاآا1W×١1ءi1اهM‏ العديد من الطرائق التي تسهل إحراج لغة التأشير المطلوبة. فعلى سبيل المثالء 


99 99 


تقوم WriteBeginTag(ً tag Name”)‏ بفتح عنصر جدید وتقوم Write Attribute) 1202e”, ” a] ue”)‏ بإرسال خر ج بواصفة 


ضمن عنصر ما. کما تقوم )هع 8ع )اس بإرسال خرج تأشير »>0٤/<‏ في حين تقوم کل Write Text( tex”) ja‏ 
و) WriteEncoded Tex t( tex”‏ بكتابة نص إلى الخرج بخيار إما باستخدام ترميز لتمثيل المحارف الخاصة أوبصورة مباشرة. 


معالجة واصفات الإظهار ضمن موائمات الأجهزة: 
تدعم جميع عناصر التحكم المحمولة نفس المجموعة من خصائص الإظهار الأسلوب ...Font «BackColor «ForeColor Jia‏ 
وتكون معظم واصفات الإظهار استشارية بمعنى أنه سوف يتم احترامها وتطبيقها في حال ثبت دعم الجهاز لها. 
يقرر النص البرمجي الخاص بصف موائم الجهاز إمكانية ترجمة خاصة الإظهار التي قام المطور باستخدامها وذلك بالتأثير ضمن 
الخرج المرسل إلى المستخدم. 
من البديهي مثلاً عند إسناد القيمة ل٠۸‏ إلى الخاصة ۴٥۲١٣٥10۲‏ مثلاً أن تعمل بشكل طبيعي على مستعرض 1۲ ملون ولكن لن 
يكون لها أي تأثير على مستعرض ۷11.1 وحید اللون. تسھل صفوف ۲٤ا٣‏ W×٥e۲اiطMo‏ إرسال خرج يميز العناصر 
المطلوبة باستخدام لغة التأشير المناسبة. 
تكون الطر اثق الموضحة أدناه للصف ١‏ عا 1W×١11۴1طهM1‏ هي الأكثر استخداماً لتطبيق هذا التمايز في الخرج. 

€ )eاsty :Enter Layout Style‏ تقوم ببدء کتلة مقطع جديد ويُطبق عليها الأسلو ب المتضمن في غرض عآارا؟. 

€ )eاsty Exit Layout Style‏ : تقوم بإغلاق كتلة مقطع. 


EnterStyle( Style sty 1e) €‏ : تقوم بكتابة تأشيرة الفتح. 
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tye) €‏ eاe)StyاExity:‏ تقوم بكتابة تأشيرة الإغلاق. 


ذكرنا أنه إذا قمنا بإنشاء موائم جهاز جديد لجهاز ا١۷‏ يجب الوراثة من الصف 
Lİ System. Web.UI.MobileControls. Wm1ControlAdaper‏ إi\‏ کنا نريد إنشاء موائم 1١1‏ فيجب الوراثة من الصف 
.System.Web.UI.MobileControlAdapter‏ 


تكوj‏ ll¡¦طرق WmIlControlAdapter pئÛlge jaض EBxitStyle «EnterStyle «ExitLayout «EnterLAyout‏ 
و Htm Control Adapter‏ على علم بمحدودية الصف الخاص بالجهاز الذي تعمل عليهء لذلك فهي تعيد فقط التأشيرات المناسبة دون 
تضمين الواصفات التي لن تعمل على هذه التجهيزات. في معظم الحالات ولضمان ضبط واصفات الإظهار المناسبة عند إرسال الخرج 

إلى الجهاز يكفي فقط استدعاء الطريقة ۲ع M0111 ×)W‏ وتمرير خاصة ع1ا إليها بشكل مشابه لما يلي : 


WEILEL.ENTCEFLOVOUL(ENIS.SEYIE); 77 can lecve of the THIS. Tor 
brevity 


إظهار النص ڊعد اwتخدlم :EnterStyleg EnterLayout‏ 
یجب علینا دائماً ضمن موائمات تجهيزات ا0۷/N‏ استخدام الطريقة ۲×٥۲1ءل,٥۸‏ لتخريج التأشيرات مباشرة بعد استدعاء 


.EnterStyle s EnterLayout 
تقوم طريقة ٤×٠1١ء ١ء8۸ باستدعاء الطرق المسؤولة عن إرسال التأشيرات المنسقة إذا كانت مطلوبة.‎ 
فعلى سبيل المثالء يقوم النص البرمجي التالي بإخراج مقطع وتأشيرات تنسيق كما نتوقع:‎ 
writer.EnterLayout (Style); 


writer.EnterFormat (Style) ; 
writer.WriteBeginTag ("table"); 


ولكن ما بجت انقخدامة فعا هو : 


writer.EnterLayout (Style) ; 
writer.EnterFormat (Style); 
writer.RenderText ("table", false, false); 


ملاحظة هامة : لا ينطبق هذا القيد على الغرض Htm1Mobile ext Writer‏ بل على llئغرض WmlMobile ext Writer‏ aaط.‏ 


يمكننا الاستعلام عن واصفة محددة للأسلوب باستخدام غرض عار لعنصر التحكم حيث يحدد هذا الغرض مجموعة من الثوابت مثل 
Style.BoldKey «Style. AigmnetKey‏ و e.t1cKeyاty.‏ یمکن استخدام هذہ الثوابت کدلیل لخصائص الغرض عارا؟ كما 


Alignment alignment = (Alignment)Style[Style.AlignmentKey, true]; 
تشير قيمة المعامل الثاني في حالة كانت قيمتها (عءاه۴) إلى إمكانية استعادة القيمة المطبقة مباشرة على عنصر التحكم» أنا إذا كانت‎ 


قيمتها 1٠٠٠‏ فتشير إلى إمكانية استعادة القيمة الموروثة من عنصر التحكم. 


استخدام عناصر التحكم المخصصة وموائمات الأجهزة: 
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رأينا في بداية هذه الجلسة كيف يمكن إنشاء عنصر تحكم مخصص وموائمات أجهزة خاصة بهذا العنصر. سنقوم الآن باستعراض مثال 


%5@ Register TagPrefix="CMcustom"™ 

Namespace="MSPress.MobWeb.CustomControls"™ 
Assembly="CustomMobileControlLibrary" %> 

@ Register TagPrefix="mobi le" 
Namespace="System.Web.UI.MobileControls" 
Assembly="System.Web.Mobile" %> 

@G Page language="c#" 
Inherits="System.Web.UI.MobileControls.MobilePage" $%> 


<mobile:form id="Forml1" runat="server" Alignment="Center"> 
<CMcustom: CMTable id="CmTable1l" title="A title" runat="server" 
StyleReference="title" Font-Size="Small" 
1 
6 


Item1Text="Simple" Item2Text="Table" > 

</CMcusEom: CMTasble. 

SEMEUS E om: CMnable A> CMI ADICeZL FURNACE 
Item1Text="second" Item2Text="table" 
Font-Size="Large" Font-Bold="False" Font-Italic="True" 
Alignment="Left"> 

</CMCusEon: CMTablez 


< mou le 2f OEM 


ولنتمكن من تشغيل هذا التطبيق لا بد لنا من ضبط تعريف مجموعة موائمات الأجهزة الجديدة ضمن ملف الإعداد عiگWeb.c0n‏ 


.<mobileControls>......<MobileControls pull وذلك ضمن‎ 


يجب تعريف مجموعة موائمات جديدة ترث من مجموعة الموائمات القياسية المعرفة ضمن الملف عاگ«هء.٥«1طعمص‏ وإضافة إعدادات 


لعنصر التحكم الجديد والموائمات الخاصة به. 


يمكن أن ييدو النص المعدل للقسم <ءMob¡1eC0»†r01>‏ ضمن ملف عا1گ«ەc. We‏ كما يلي: 


CEONTIGUTaAEIOR 
<system.web> 


<mobileControls 
sessionStateHistorySize="6" 


cookielessDataDictionaryType="System.Web.Mobile.CookielessData"> 
<device name="CMcustomHtmlDeviceAdapters"™ 
inheritsFrom="HtmlDeviceAdapters"> 
EOE EO 
name="MSPress.MobWeb.CustomControls.CMTable, CustomMobileControlLibrary"™ 
adapter="MSPress.MobWeb.CustomControls.Adapters.HtmlCMTableAdapter, 
CUS E CMOS IECORE COLL ea 1> 
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</device> 
<device name="CMcustomcHtmlDeviceAdapters" 
inheritsFrom="ChtmlDeviceAdapters"> 
SEORIE EO ll 
name="MSPress.MobWeb.CustomControls.CMTable, CustomMobileControlLibrary"™ 
adapter="MSPress.MobWeb.CustomControls.Adapters.HtmlCMTableAdapter, 
CUS ECMO LECOREr OLLIE AE 7S 
</device> 
<device name="CMcustomUpWmlDeviceAdapters" 
inheritsFrom="UpWmlDeviceAdapters"> 
EOE E O 
name="MSPress.MobWeb.CustomControls.CMTable, CustomMobileControlLibrary"™ 
adapter="MSPress.MobWeb.CustomControls.Adapters.WmLlCMTableAdapter, 
CustomMobileControlLibrary" /> 
</device> 
<device name="CMcustomWmlDeviceAdapters" 
inheritsFrom="WmlDeviceAdapters"> 
EOE JE OAL 
name="MSPress.MobWeb.CustomControls.CMTable, CustomMobileControlLibrary"™ 
adapter="MSPress.MobWeb.CustomControls.Adapters.WmlCMTableAdapter, 
CUS E OMMObA lLECOMNE EO LLSOEAEYL 1> 
</device> 
€ /MOOLLECONEEOLSS 
</system.web> 
€ COME LO UE EE LOME 


نلاحظ بأننا قمنا بمقابلة كل موائم جهاز مع عنصر التحكم بالصيغة : 


<control name= "controlName, assembly" adapter="adapterName, assembly" 


3 


استخدمنا ضمن هذا النص البرمجي ملف تجميعي يحتوي صف عنصر التحكم إضافة إلى صفوف موائمات الأجهزة وهوبالاسم 
Custom MobileControl[Library. d1‏ حیث یعرف کل قسم <عع۷iعل>‏ مجموعة موائمات أجهزة. 


لا بد لنا من الانتباه إلى إعطاء أسماء فريدة لمجموعات موائمات الأجهزة تلك. 
نلاحظ أننا قد استخدمنا في CMcustomWmlDevice Adapters , CMcustomHtmlDevice Adapters «lll! lila‏ و .l|Sa‏ 


سنحصل عند تشغيل هذا التطبيق على نتيجة شبيهة بما يلي : 
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ا× ادا lol xl‏ ا اا 


File Zoom Tools Help 
E erme Ore 0:56 


http:f#132,168.,0, 10fmitbocksampl ” 


simple Table 


sarang tahle 


Yiew Tools +” 


بناء عناصر التحكم المخصصة المرتبطة بالبيانات 


إذا عدنا إلى عنصر التحكم الذي قمنا بيناءه عبر هذه الجلسة فسنجد أنه لن يكون مفيداً جداً إذا اقتصر على إظهار صف وحيدء ولكنه 
یمکن أن يصبح مفيداً إذا تم ربطه بمصدر بیانات. لذلك سنقوم بإاجراء تحسینات على عنصر التحكم CMTable‏ الذي قمنا بإنشاءه 
وسيكون هدفنا فهم كيفية إجاء عملية ربط عنصر تحكم مخصص بمصدر بيانات. 


لدعم الربط بالبيانات يجب إجراء الخطواء التالية: 
إضافة الخاصة من النمط ١٥ء‏ 11ه٣1‏ والتي تحدد مصدر البيانات ويفضل تسمية هذه الخاصة باسم عc (4)5٣‏ للمحافظة 
على الانسجام مع التسمية الموجودة في العناصر المرتبطة الأخرى. 
إذا أردنا دعم الارتباط بمصادر البيانات من النمط عءإuاه؟ء1ل1‏ (مثل أغراض 86ا4( في 1٤۴.N؟A)‏ يجب إضافة خاصة 
من نمط S11‏ باسم .(at4 M۴‏ يمكن عبر هذه الخاصة تحديد اسم عضو البيانات أوالجدول مثلا لتم استخلاصه من 
مصدر البيانات. في مثالنا هذا سيتم دعم مصادر البيانات من النمط 1eط۲4٤ 1٤" u‏ أي أنه لن یتبنی الخاصة .Data Member‏ 
قم بإضافة خاصة تحدد أي من عناصر البيانات سيتم استخلاصها من كل صف ضمن مصدر البيانات. في مثالنا يحتوي عنصر 
التحكم 58ءa1‏ 11 CM‏ على الخاصتين 141ء¡1ex)۴ (ata ex{۴iء142و 2ata‏ التي تحدد العناصر التي سيتم إظهارها 
ضمن العمود الأول والثاني. كذلك يحتوي عنصر التحكم على الخاصة 14ء۴ عں 414۷1( التي تحدد القيمة المخفية التي يقوم 
التطبيق بتخزينها لكل عنصر في القائمة. 
عندما يقوم عنصر التحكم بقراءة مصدر البيانات لا بد له من استخلاص عناصر البيانات المحددة في 11عData1e×x)۴1‏ 
و 2 Data TextField‏ و ata ValueField‏ وتخزينها ضمن الغرض. تشبه عناصر اللائحة ضمن عنصر ت>Sۃp CMTableDB‏ 
ما هومتوفر في Îغرlض .Listg SelectionLists «Mobi1leListI(erı‏ 

5- يجب أن نقوم بتخزين أغراض ١ء‏ ]ء11 ء1طة CM ١‏ الذي يمثل عناصر اللائحة ضمن ١٥10اء11ه)‏ والتي تساعد الصف 
"N٧‏ في الوصول إليها كخاصة وليصبح بإمكاننا التعامل معها. وكما هي الحال أيضاً مع عنصر التحكما11 يمتلك 
عنصر التحكم المخصص 8(ء1ط14 CM‏ خاصة بإسم [٠١‏ للمساعدة في الوصول إلى غرض 
MobileListIltemCollection‏ الذي يحتوي غر اض .CMTabl1eListIe ıı‏ 


Universal Knowledge Solutions s.a.1 
256 


6- تقوم الطريقة ١١81هه(‏ بإداء عملية قراءة البيانات من مصدر البيانات ثم بناء أغر اض CMT ab|leList 1e”‏ وإدار ج تلك 


الأغراض ضمن غرض .MobileListIte Collection‏ 


يمتل النص البرمجي التالي الصف ١1ء‏ اعااة1 CM‏ الذي يقوم بتخزين عناصر اللائحة. يرث هذا الصف وظائفه من الصف 
MobileListItem‏ ويقوم بإضافة الخاصة 1١×2‏ لتخزين العنصر الذي يستخدمه العمود التاني: 


using System; 
USING SYSTEM. Web. UL.MobileConirols; 


namespace MSPress.MobWeb.CustomControls 
{ 
/// <summary> 
/// Stores details of items displayed in the CMTableDB control. 
A11 <O 
public class CMTableLlListItem : MobilelistItem 
{ 
// Add a properly to hold text displayed in column 2. 
private String _text2; 


BUSS SEEING MEZ 

{ 
Gel { FEELUrT _lexTl;, | 
SEE | _ECEZA = UANUSE | 


} 


public CMTablelListItem() : base() 
{ 
کک و‎ 
} 
ulol 1 @ CMTE EL SE 1 EO 
System.Object dataltem, 
System.String text, 
SVS EEM. SEE IRS EEE 2, 
SYS EeM. SEI iNG value) 
base (dataltem, texl, value) 


EEA = EEA, 


أما النص التالي فهو النسخة المحسنة من الصف ١1ا۲2 KOM‏ لدعم ربط البيانات: 
using System;‏ 
using System.Collections;‏ 
using System. Reflection;‏ 
uUSiNG System.Web. UL. MobileControls;‏ 


namespace MSPress.MobWeb.CustomControls 


{ 


/// <summary> 
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//4 Custom control uill from Serateh using dala SindinG 

/// This control inherits from PagedControl rather than 
MobileControl. 

f11 <S > 

public Class CMIablée : PadgedCOnEr oL 

{ 


private ICollection _dataSource = null; 

private MobilelListItemCollection _items = 

new MobilelListItemCollection () ; 

private String 1tle, _dataTextField1, _dataTextField2, 
_ dataValueField; 


public CMTable() 
1 

TELE E; 
Dat ANExEELELGN = YUE 
Dee AU AE CZ = MUS 
Daa Value Rie 


} 


PUIG ICOLLECEION Dalla SOU Ce 
{ 
get { return _dataSource; } 
Sel {| _datasource = valle; |} 
} 


/// <summary> 


/// Gets and sets the field displayed in the first column. 
/// </summary> 
public String DataTextField1 
{ 


get { return _dataTextFieldl; } 

Sel (1 data lextEieldl > value: | 
} 
/// <summary> 
/// Gets and sets the field displayed in the second column. 
/// </summary> 
BUDLIE SEEING DacalexSEIe LAZ 
{ 


get { return _dataTextField2; } 
Set { _datalextElield2 = value; j} 
ا‎ 


/// <summary> 
/// Gets and Sets tne field Stored as a hidden value. 
/// </summary> 
public String DataValueField 
{ 
get { return _dataValueField; } 
Sel {| Qata valueield — value; | 


} 


/// <summary> 
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/// Gets the collection of items displayed in the table. 
/// </summary> 

public MobilelListItemCollection Items 

{ 


Jet { retUrn _MtenSs; } |} 


//InternalItemCount and ItemWeight are necessary to 
{1 SUBBOLE PpacinaLlloll. 
protected override int InternalItemCount 


1 


GEE { BeEEUEN lEeMS 1 COUNE;, | 


} 


// This method can be implemented in the device adapter 
// classes if the representation differs from device to device. 
// However, an item in this control always takes up one line. 


protected override Int32 ItemWeight 
1 


get { return ControlPager.DefaultWeight; } 
} 


/// <summary> 
/// Gets and sets the title displayed on some WML devices. 
111 SUMS 
pUCIIE SETTING Tile 
{ 
GEE (| EFeEUED El 
set { _title = val 


} 


// Override DataBind method of base class to implement 
// data DIRIN LOGIC 
BUSI Suer ide UONA DalaCi NS) 


1 


// Evaluate data binding expressions on the control itself. 
base.OnDataBinding (EventArgs. Empty) ; 


IE (DEAS Ce 1= MULL) 
{ 
// Iterate DataSource. 
TEnumerator dataEnum = DataSource.GetEnumerator () ; 
while (dataEnum.MoveNext () ) 


{ 


l1 CTE lE HU ICED to CIC dala lG E. 
CMTablelList Item item = 
mew CMa e SENE eM (OA EAEN UM. CUE eM E 


System. Type objectType = 
dataEnum.Current.GetType(); 
EBOREREY IDE O GEFO 
objectType.GetProperty (this.DataTextField1); 
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iE (aBEOP l> MUON) 
MEE. MEXE 
aProp.GetValue (dataEnum.Current,null).ToString(); 
aProp = 
objectType.GetProperty (this.DataTextField2); 
iE (aPEOS 1> mULL) 
item.Text2 = aProp.GetValue 


(Oa Ea ENUM. CUE EeME, NULL) TOE RO (J 
aProp = 
objectType.GetProperty(this.DataValueField) ; 


if (aProp != null) 
item.Value = aProp.GetValue 


(Ga Ea ENUM. CUE ERE, NULL) TOSSES 


// Add item to the MobileListltemCollection. 
1tems.Add (item) ; 


// 2d Ene Mableli SEIEeM aS a CMIldS CONEFOL 
EMS , COME OLE ACO (ESM) F 


يجب استخدام الخاصة 1٠١‏ لصف عنصر التحكم عااة1 CN‏ ضمن طريقة امل R۸”‏ في صف موائم الجهاز»ء للمرور على عناصر 
MobileListltemCollection‏ والتي تقوم بتوليد تأشيرات الخرج لكل عنصر ضمن القائمة. 


يكون النص التالي خاص بموائم الأجهز ة الخاص ب1 11M‏ لعنصر التحكم المخصص و و :HtmICMTab1e Adapter‏ 
using System;‏ 
using System.Web.UI;‏ 
using System.Web.UI.MobileControls;‏ 
using System.Web.UI.MobileControls.Adapters;‏ 
using MSPress5,.MobWeb.CustomControls;‏ 


namespace MSPress.MobWeb.CustomControls. Adapters 
{ 
E 
* HtmlCMTableAdapter class 
public class HtmlCMTableAdapter : HtmlControlAdapter 


1 
protected new CMTable Control 


{ 
get { return (CMTable)base.Control; } 


} 


public override void Render (HtmlMobileTextWriter writer) 
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MobilelListItemCollection items = Control. Items; 
E (TEME  COUME =— 0) 
{ 

EEUU N 


} 


I1Nl padgeSsStart = Contfol.EIrStVisibleItenIndex; 
init pag€eSize = Control. VisibleltemCount ; 
1f (items.Count < pageSize) pageSize = items.Count; 
SLEING tableSurfix = WY; 
Alignment alignment = 
(Alignment) Style [Style.AlignmentKey, true]; 
if (alignment != Alignment.NotSet && alignment != 
Alignment .Left) 
{ 


writer.Write ("<div align=\""); 
WEIL. WEITCeElaLIONMENT <. TOSETÎING OY, 
WELLE. WEILELInE (TTT), 
EEOC EI = VENA E 


writer.AddAttribute ("width", "90%"); 
Wr Eer .ASOAEE EA OUEe ( Cel ISA ddiNOSL, SN). 
writer .RenderBeginTag ("table"); 


writer.WritelLine (""); 
mer CST OT E O ECC 


{ 


CMTEOLELT SE 1ES 1EM = 
(CMTableListItem) (items [pageStart + i1); 
E i E E ¢ E 1 EE (E SEG > ECW) f 
writer.EnterFormat (Style) ; 
writer.WriteEncodedText (item. Text); 
writer.ExitFormat (Style); 

WE TEE WEI EE (LCE EOE). 
writer.EnterFormat (Style); 
writer.WriteEncodedText (item. Text2) ; 
writer.ExitFormat (Style); 
WEILer.WriteLine ("<7 TEIS></ EEE), 


ِ 
writer.RenderEndTag(); 
writer.WritelLine (tableSuffix); 
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دعم التقسيم الآلي والمخصص إلى صفحات 


يجب أن يدعم أي عنصر تحكم يقوم بتوليد كمية خرج كبيرة» آلية التقسيم إلى صفحات. فإذا تم استخدام مجموعة كبيرة من البيانات مع 
عنصر التحكم المرتبط وتم تحديد الخاصة عه للنموذج الحاوي على عنصر التحكم هذا إلى القيمة ٠1۲٠‏ يجب السماح لعنصر 
التحكم بإرسال خرج مكون من مجموعات جزئية من العناصر التي يتم توزيعها على شاشات متتالية. 


تتضمن عملية دعم التقسيم إلى صفحات المراحل التالية: 

1- يجب أن يرث عنصر التحكم من الصز PagedContro|‏ بدلا عن M0110 n)۲01‏ . بالتالي سیحصل عنصر التحکم علی 
جميع المزايا التي يمكن أن يستخدمها في التقسيم المخصص إلى صفحات: كالخاصة 1te ٣0u«٤‏ وانحدثLoadItems‏ . 

2- يجب القيام بإعادة تعریف الطریيقة ۳٣01۸۲‏ ءع)[۵1٣٣ء)م]‏ لإعادة رقم العناصر الموجودة حالياً ضمن عنصر التحكم. كذلك 
يجب إعادة تعريف الخاصة ع۷ 1)٠٠‏ لإعادة القيمة التي تحدد لإطار عمل الصفحة كم يستهلك سطر وحيد في عنصر 
التحكم من مساحة الإظهار على الشاشة. بعد تحديد كم من عناصر التحكم والمكونات يمكن إظهاره على شاشة الإظهار» يقوم 
إطار العمل بالاستعلام من كل عنصر تحكم عن خاصة اطع1ه ۷ ١ع][.‏ يقوم إطار العمل بهذا قبل تعيين كل عنصر تحكم 
وعنصر قائمة إلى صفحة إظهار محددة. يستهلك سطر إظهار واحد وزن 100 وحدة من وحدات النظام التي يستخدمها إطار 
عمل الصفحة. توجد هذه القيمة ضمن الثابت )1طعontro1Pager.)efau1{We1.‏ تعيد الخاصة ٤اعWe1 1]en«n‏ لعنصر 
التحكم م1ااة1 KN‏ الذي نعمل على تطويره قيمة هذا الثابت كونه يستهلك سطر واحد لكل عنصر قائمة. 

3- يقوم إطار عمل الصفحة بتعيين lاlخاصة Control.FirstVisibleItemIndex‏ و lillصA Control. VisibleltemCount‏ 
لتحدد العنصر الأول الذي يجب أن يظهره عنصر التحكم وعدد العناصر التي يجب إظهارها. يجب كذلك على النص 
البرمجي الذي نقوم بكتابته للطريقة إعلرهR‏ ضمن صف موائم الجهاز أن يستخدم هذه المعلومات لتحديد العناصر التي سيتم 
إرسالها إلى الخرج. 


يتم التصريح عن نموذج وب محمول لاستخدام عنصر التحكم هذا: 
<mobile:form id="Form2" runat="server" Paginate="True">‏ 
<CMcustom:CMTable id="CmTableDB1" runat="server" />‏ 
</mobile: form>‏ 


public class MobileWebForml : System.Web.UI.MobileControls.MobilePage 
{ 


protected System.Web.UI.MobileControls.Form Forml; 
protected CMTable CmTableDBl; 


private void Page_Load(object sender, System.EventArgs e) 


{ 


// Create large array to illustrate pagination. 
ArrayList array = new ArrayList (J) j 

array.Add (new TeamStats ("Dunes",1,38,24,8,6,80)); 
aEEaY Ada (Rew leamcsEaE Ss ( LEMOEeM 2,2, SO, 20, LO, 8, OD, 
IE EAI o TEASE ES (EAGLES, 3, O, 20, O, I, OID 
array. TEAM SEAES (ZOCALO 2O O TOES) 
) 


array. TEAMS E AES Ar CRE SL, 0, 30, 20, O, 12,06 


r 


J); 
) 
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"ENOWSL O, SOIL, O, LL OD 
"CErealt ion, ,30,15, 12,1 
OSLO EO SO O US 
array.Add (new TeamStats ("Torpedo",9,38,14,10,1 
array.Add (new TeamStats ("Generals", 10,38,14,1 


(new TeamStats ( 
( ( 
( ( 
( ( 
( ( 
array.Add (new TeamStats ("Reaction",11,38,14,9, 1 
( ( 
( ( 
( ( 
( ( 
( ( 


new TeamStats 
new TeamStats 


array .Add 
EE 1E EJ o CIC 
array .Add 


AREY ACE (mew TeamMSEAES ( EEA E SL 12, O, OE 
array.Add (new TeamStats ("Caverns",13,38,14,6, 1 
array.Add (new TeamStats ("Eclipse",14,38,9,15,1 
array .Add Or AGO, LSE, 1O, L2, 107 4 
Ela ac 4. ele| Eo SMOS LL, LO O ONO, ADE 


new TeamStats 
new TeamStats 


CmTableDB1.DataSource = array; 
CmTableDB1.DataTextField1 = "TeamName"; 


e 
e 
CMAN EDEL Dalal exXEETE NGA 2 BOUMES LE, 
e 
e 


CmTableDB1.DataValueField = "Position"; 
CmTableDB1.DataBind() ; 


1 
class TeamStats 
{ 
private String _teamName; 
BEA EE UME OOS ENON, Olaved, MON, CGOmaM, OSE, OOOIMNES, 


public TeamStats (String teamName, 
IHE OC IEICD, 
int played, 

ME WOM, 

E Ql SA 

TE LOSE fF 

INE GOoINES) 


this._teamName = teamName; 
ENALSo_OOSI E 1 OM — OSI ELO 
this._played = played; 
EMS EO VOM 

ERS EGAN E GOEAVIRE, 
ENLS,_ LOSE = LOSE; 

EMIS EPONMES < OONME SF 


String TeamName GEE 1 E EULE M 1s ._teamName ; 
E EOS HELO get return TS _OOSTE N OMS 
TNE Played get return 1s._played; 

E Won get return 1S. WON; JF 
E Drawn GEE return LE, _ OEMS J | 
E Lost get return SR. NOSE I 
E Points get return lu OOLMES, 1) | 


يعطي هذا الصف على جهاز محمول صغير خرجاً يشبه الشكل: 
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لاء ا 
BE)‏ . 
Phoenix‏ 


Eagles E9 
| Zod 


| 7 | 
SSR | FE 
i Peanuts 43 


OnDataBind ثiدحنئنا استخدام‎ 


يمكننا إضافة أحداث عامة إلى صف عنصر التحكم المخصص. 


توفر عناصر التحكم القياسية المرتبطة بالبيانات الحدث 4١81هة(".ع)]‏ والذي يمكن للمطور استخدامه لتطبيق ربط مخصص 


بالبيانات. لذلك من المنطقي استخدامه ضمن مثالنا الذي يتناول عنصر التحكم المخصص اط1 .٥CMN‏ 


لاستخدام الحدث 10١048114‏ يجب التصريح عن توكيل عام لمعالج الحدث. يمكننا التصريح عن هذا التوكيل ضمن ملف النص 


public delegate void CMTablelListItemEventHandler ( 


object sender, 
CMTableListItemEventArgs e); 


يأخذ معالج الحدث معامل من النمط M1 blest ]temEven)sA gs‏ کما هوحیث يتم تعريفه كما يلي : 


public sealed class CMTablelListItemEventArgs : EventArgs 


private CMTablelListlItem item; 


public CMTableLlListItemEventArgs (CMTableListItem item) 
{ 


EMLSE ALEM = ESM 


} 
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{ 


public CMTableListItem Item 
{ 


get { return item; } 


1 


: ٤٥CM 1 abإe ءع)] ضمن صف عنصر التحكم‎ n٣ (2)81 ۸4 يمكننا بعدها تعريف التصريح عن الحدث‎ 
// Declare a static read-only object that will own the list of 


registered 
// event handlers 
private static readonly object EventItemDataBind = new object(); 


public event CMTableLlListItemEventHandler ItemDataBind 


Events.AddHandler (EventItemDataBind, value); 
} 
remove 


{ 


Events. RemoveHandler (EventItemDataBind, value); 


نلاحظ أن هذا الحدث يستخدم ال¦طر lأJ .RemoveHandler , MobileControl.Events.Add Handler‏ 


باستخدام عنصر التحكم هذا يستطيع مطور تطبيقات الوب المحمول كتابة طرق معالجات الأحداث المخصصة لحدث 
1kemDataBind.یتم‏ استخدام الطريقة لم81 02ا01 لاستدعاء معالجات الأحداث التي يصرح عنها المطور: 


protected virtual void OnItemDataBind (CMTableLlListlItemEventArgs e) 
{ 


CMTablelListItemEventHandler onltemDataBindHandler = 
(CMTableListItemEventHandler) Events [Event ItemDataBind] ; 

ME (ORT EEMDaAE ABHROANALEE C> MULL) 
onlItemDataBindHandler (this, e); 


وأخير ا يمكننا استدعاء الطريقة ل”481)ة[ ”)آم0 في كل مرة يتم فيها بناء غرض e۸)])ء¡ CM 1a1‏ أناء قراءة عنصر 
التحكم عم1ااة1 KN‏ المعلومات من مصدر البيانات. 


يجب إنشاء غرض M1 abاeListI[tem ùj CMTableListItem Eve 1A] gs‏ وتمریرە إلى الطريقة .0n1)e 024811٩‏ بھذە 


الطريقة يستدعي عنصر التحكم طريقة معالج الحدث dدa81ة‏ .)آ0 التي تم التصريح عنهاء مما يوفر إمكانية تخصيص عملية 
الربط بالبيانات. 


| public override void DataBind() | 


{ 


// Evaluate any data binding expressions on the control itself. 
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base.OnDataBinding (EventArgs. Empty) ; 


NE (Dal acoUaee ll — UMN) 
{ 
// Iterate DataSource, creating a new item for each data item. 
IEnumerator dataEnum = DataSource.GetEnumerator () ; 
while (dataEnum.MoveNext () ) 
{ 
// CEeate LEM 
CMTablelListlItem item = 
mew CMTE SEN ECEM (ASAE AENUM CU Een, LL ES 


// intervening code not shown 


1/ Add iEem EG EME Mob lel iS El EeMCOL lECE1ON OE EMe COME OL 
_ items.Add (item) ; 


1/1 Add ERhe lableli SEIEEM aS 4 CMIIlAS CONE OL 
EMIS. COREEOLS ASO ECM 


CMTableLlListItemEventArgs e = new CMTablelListItemEventArgs 


OnItemDataBind (e) ; 

// After any ItemDataBind events have been called, the 
// Dataltem property has no purpose and is not relevant 
1/1 Od OOSEOAERK, SO CIEE Uo 

i Eem. Data lE em > MUN; 
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أمان الحلول المحمولة واللاسلكية 


الكلمات المفتاحية: 


ملخضص: 
سنتعرف في هذه الجلسة التعرف على المكونات الأساسية التي تتدخل في عملية بناء بيئة آمنة ثم ننتقل إلى التهديدات الأساسية للأمان 
والتي يجب الانتباه لها. 
وأخيراً سوف نغطي بعض تقنيات الأمان والمقاييس التي يجب مراعاتها في تطبيقاتناء وسنقوم بالتعرف بشكل أعمق على الأمان في 
البروتوكول ۷۸۴ والمشاكل التي يطرحها. 
أهداف تعليمية: 
يتعرف الطالب في هذا الفصل على : 
مكونات البيئة الآمنة 
المخاطر الأمنية 
تقنيات الأمان 
مقاييس الأمان الأخرى 
الأمان في بروتوکول ۷۸۲ 


ملاحظات بسيطة حول الأمان على مستوى التطبيق 
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مبادئ الأمن 


قبل مناقشة عناصر الأمان المحيطة بالتطبيقات المحمولة في المؤسسات لا بد من استعراض مقدمة سريعة عن مبادئ الأمان وتقنياته. 
سنبدأً بالاطلاع على المكونات الأساسية التي تتدخل في عملية بناء بيئة آمنة ثم ننتقل إلى التهديدات الأساسية للأمان والتي يجب الانتباه 
لهاء وأخيراً سوف نغطي بعض تقنيات الأمان والمقاييس التي يجب مراعاتها في تطبيقاتنا. 


إنشاء بيئة آمنة: 

للوصول إلى أمان (اتصال من نهاية إلى نهاية) يجب أن نأخذ بعين الاعتبار البيئة كاملة بما في ذلك طبيعة الوصول في المؤسسةء 
مكونات الكيان الوسيط والتطبيق الزبون. 

إن ضمان أمان (اتصال من نهاية إلى نهاية) يعني ضمان أمن البيانات على كامل المسار من المرسل إلى المستقبل. وللوصول إلى هذا 


النوع من الأمان لا بد من تحقيق مجموعة من الأهداف الأساسية وهي: 


1 التحقق من الهوية: 

دهرااجر اء الع قات كزن لخن ار رة فی من آنا ی ك مه ال ف اكات اا على مون اا 
طبقة الشبكة والثائية طبقة التطبيق. 

تتطاب الشبكة التحقق من هوية المستخدم قبل الموافقة على وصوله. حيث يمكن اتمام هذه العملية ضمنيا اعتمادا على الجهاز 
أوالموديم أوبصورة منفصلة باستخدام تقنيات مختلفة. 

أُما على سوية التطبيق فتعتبر عملية التحقق من الهوية مطلوبة على سويتين الأولى سوية الزبون والثانية سوية المخدم. فللوصول 
إلى بيانات المؤسسة» يجب على الزبون أن يثبت للمخدم بأنه من يدعي» وفي نفس الوقت قبل أن يسمح المستخدم لمخدم خارجي 
بالاتصال به يجب على المخدم أن يظهر هويته إلى التطبيق الزبون. 

إن أيسط طرق التحقق من الصحة هي استخدام اسم المستخدم وكلمة المرور أما الطرق الأكثر أماناً وتعقيدا فتتضمن الشهادات 
الرقمية والتوقيع الرقمي. 


2- سلامة البيانات: 

إن التكق من ساكة لبيقات بني لتك بان الاك لم رت يها ار اسر اها باي طريفة أغاء ها بين المرسل والسكل: 
يمكن الوصول إلى هذا الغرض باستخدام تشفير البيانات مع تقنية اختبار المجموع "۳ C"۴٥۸51‏ أورمز رسالة التحقق ١۸٥‏ 
و فق م ا کن انا ی کور ا ا ر ل ا ما من ل اسل به 
خاب 046 رار هة مع آل 046 اتشر شمن الزساة لاك من تطاقها: ا ك طاق مك انسل فاك من ان 
الك بارس رزلا تكن السل إسان الرمالة اكرون رتا غير سيت 
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3- السرية: 

السرية هي أحد أهم نواحي الأمان. وهي تتلخص في المحافظة على خصوصية البيانات والتأكد بأنه لا يمكن رؤيتها من قبل 
أطراف غير مرغوب بهم. 

علكما يتكلم الأشخاص عن الأمان فى التظام فيم غالبا ما يهتمون بالمطومات الساسة كمطومات بطاقات الإئتمان والسجلات 
الصحيةء التي لا يجب أن تكون مرئية للأشخاص ذوي النوايا السيئة. تعتبر عملية تشفير البيانات بحيث تصبح غير مقروءة لأي 
شخص عدا المُعترف عليه هي الطريقة الأكثر شيوعاً في هذا المجال. 


4- السماحية: 

هي عبارة عن إجراء تحديد سوية الوصول لمستخدم ما وحق هذا المستخدم بالقيام بأفعال معينة. تكون السماحية عادة شديدة 
الالتصاق بموضوع التحقق من الهويةء فما أن يتم التحقق من هوية مستخدم حتى يتم تزويده بالسماحيات المحددة له. يجري عادة 
استخدام ما يسمى لوائح التحكم بالوصول ا٥۸‏ للمساعدة في تحديد السماحيات. 

فعلى سبيل المثالء قد يمتلك جميع المستخدمين حق القراءة من مصدر البيانات ولكن يمكن فقط لمدير النظام ومصادر أخرى 
موثوقة أن تمتلك حق الوصول والكتابة فيه. 


عدم الإنكار: 

يتلخص عدم الإنكار في جعل الأطراف مسؤولة عن المناقلات التي اشتركت أوقامت بها. تتضمن هذه العملية التعرف على 
الأطراف بطريقة لا يمكنهم فيها لاحقاً إنكار اشتراكهم في مناقلة ما مما يعني أنه بإمكان مرسل الرسالة أومستقبلها التأكيد لطرف 
ثالث بأن المرسل قد أرسل هذه الرسالة فعلاء ويأن المستقبل فد قام باستلام تفس هذه الرسالة. للقيام بهذا العمل لا بد من استخدام 
توقيع الكتروني وختم زمني يمكن التحقق منه مع كل رسالة من قبل طرف تالث موثوق. 


المخاطر الأمنية 


تئر عطاية يتا حل أمان عماية ية الأيمكن تنفد ها دون التكرف و يضور 4 و أضة على المكاطر المحتاة: 
فسواء كانت البيانات تنتقل بصورة سلكية أولاسلكيةء لا بد من اتخاذ الاحتياطات اللازمة ضد المخاطر التالية: 


انتحال الهوية: هوعبارة عن عملية الحصول على وصول إلى نظام أوتطبيق ما بالتظاهر بأنه مستخدم ما. فإذا تمكن المستخدم من 
الوصول إلى النظام أصبح بإمكانه إنشاء استجابات مزورة أورسائل قد يكون غرضها الاستعلام عن معلومات إضافية للحصول 
على سماحية أعلى ضمن النظام. لذا بتبر انتحال الهوية مشكلة أساسية في الأمن على الإنترنت لأنه يعطي للشخص المهاجم 
إمكانية إيهام مستخدمي التطبيق بأنهم يتصلون بمصدر موثوق كالبنك مثلاء بينما هم يتصلون حقيقة مع جهاز المهاجم مما يساعد 
المهاجم في الحصول على معلومات هامة وحساسة. 


التنصت: 


هي عبارة عن آلية تحدم لمر ية تدقق البيانات عبر الشيكة. يمكن لهذه الآلية أن تستخدم لأغراض جيدة ترتبط هذه العملية عامة 
بعملية نسخ غير مسموحة للبيانات على الشبكة بحيث يتم الاستماع لكل ما يدور عليها وبالتالي يمكن لأطراف غير مرخصين 
الحصول على معلومات حساسة تسمح لهم بالتسبب بأذى لنظام المؤسسة أولمستخدمي التطبيق. 
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تعتبر عملية التنصت خطرة لأنها سهلةء وبات الحصول على الأدوات الخاصة بها سهلا. 
يكمن الحل في عملية تشفير البيانات والتأكد من أن خوارزمية التشفير غير قابلة للفك (قدر الإمكان) فعلى سبيل المثال»ء اكتشف 
الكثير من مستخدمي الشبكات اللاسلكية بأن التشفير ۷۴۴ ليس كافياً لحماية البيانات. 


العبث: 

العبث بالبيانات (ويسمى أيضاً تهديد سلامة البيانات) هوعملية التعديل على البيانات من الحالة الأصلية لها. غالبا ما تتضمن هذه 
العملية اعتراض إرسال البيانات كما يمكن أن تحدث على البيانات المخزنة على المخدم أوالزبون. 

يتم تمرير البيانات عادة على أنها البيانات الأصلية. 

تعتبر عمليات التحقق من الهوية والتحقق من السماحية من وسائل الحد من هذا التهديد. 


السرقة: 
تعتبر السرقة مشكلة متأصلة في الحلول المحمولةء إذ لا نتكلم فقط عن سرقة الجهازء بل عن سرقة أي معلومات قد تكون عليه. 
يمكن أن تشكل هذه المشكلة تهديداً كبيرأً في حالة التطبيقات العاملة على أجهزة الزبون الذكي كونها تحتوي على البيانات التي 
غالباً ما تكون سريةء لذلك يجب اللجوء إلى القواعد التالية لتأمين التجهيزات المحمولة: 

إقفال الجهاز بتركيبة من اسم مستخدم وكلمة مرور لمنع الوصول السهل إلى البيانات. 

التحقق من الهوية عن الدخول إلى أي تطبيق على الجهاز. 

عدم تخزين كلمات المرور على الجهاز. 

تشفير المعلومات على أي واسطة تخزين. 

تحسين سياسات الأمان العامة لمستخدمي الأجهزة المحمولة. 


تقنيات الأمان 


بعد أن قمنا بالاطلاع على المخاطر التي يمكن أن تهدد الأمان في الحلول المحمولة سنستعرض أهم التقنيات المستخدمة للتقليل من هذه 
المخاطر : 


تعمية وإخفاء البيانات: 

تهدف تعمية وإخفاء البيانات إلى السماح لطرفين بالاتصال وتبادل البيانات بشكل يمنع طرف ثالث من فهم ما يجري إرساله. 

تعتبر هذه التقنية أحد المتطلبات الأساسية في بيئة آمنة كونها تتعامل مع جميع نواحي النقل الآمن للبيانات بما يتضمن التحقق من الهوية 
والتوقيع الالكتروني. 

تعتبر مبادئ عملية التعمية بسيطةء ولكنها عملية معقدة جداً من الناحية العملية وبالأخص في حالة التطبيقات المحمولة الكبيرة. 


الخوارزميات والبروتوكولات والتطبيقات: 
تعمل التعمية في عدة سويات. السوية الدنيا هي سوية الخوارزميات. تصف هذه الخوارزميات المراحل المطلوبة لعملية تتمحور حول 
تحويل البيانات من تنسيق إلى آخر. أما البروتوكول فيعبر عن التوصيف الكامل للإجرائية التي تقوم بتنفيذ فعل التشفير بما يتضمن 
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المعلومات اللازمة حول أي طارئ يمكن أن يحصل أثتاء هذه العملية. 

إن التمييز بين خوارزمية التشفير والبروتوكول هام جداً لأن استخدام خوارزمية تشفير ممتازة لا يعني بالضرورة ترجمتها إلى 
بروتوكول جيد» فالبروتوكول مسؤول عن أكثر من عملية التشفير بحد ذاتها ويتضمن عمله نقل البيانات إضافة إلى تبادل المفاتيح. 

أما التطبيقات فتتوضع فوق سوية البروتوكول» ولايعني البروتوكول الجيد بالضرورة تطبيقاً آمناً لأن التطبيق بحد ذاته قد يقود إلى نقاط 
ضعف ومشاكل أمن أخرى. 


تشفير البيانات: 
ر ادر ا ای ا اك ورل تون مر وات مى ن رم ن فط غر قان رة ي 
القص المشقر مما يسح بالحفاط على خضرزصية البياات الصاة ست عند تكن لشكاص غير مرخضين من الوصرل يها 
الطريقة الوحيدة للتمكن هن قراءة البيانات هي بتحريلها مجددا إلى التموذج الأصلي باستخدام إجراء يسمى فك التشقير. تدعى 
طريقة التشغير وفك التشفير الكوارزمية أو الشرفرة 


يوضح الشكل التالي مبدأً التشفير» حيث يتم نقل المعلومات عبر قناة نقل عامة بشكل مشفر لمنع أي متلصص على الخط من فهم 
البيانات التي يتم إرسالها. 


مخدم اأؤسسة 


تستخدم الخوارزميات الحديتة المفاتيح للتحكم بعملية تشفيروفك تشفير البيانات. فعند تشفير رسالة ما لن يتمكن إلا المستخدم الذي 
يحمل المفتاح المناسب من فك تشفير هذه الرسالة. تصنف خوارزميات التشفير المبنية على المفتاح إلى نوعين: المتناظرة وغير 
المتناظرة. 


تستخدم الخوارزميات المتناظرة مفتاح وحيد لتشفير وفك تشفير كل الرسائل. يستخدم المرسل المفتاح ليشفر الرسالة ومن ثم يرسل 
الرسالة إلى المستقبل المطلوب. عند استلام الرسالة يستخدم المستقبل نفس المفتاح لفك تشفير الرسالة. 
تعمل هذه الخوارزمية بشكل جيد عند إيجاد طريقة آمنة لنقل مفتاح التشفير بين المستخدمين» كالاجتماع مثلاً قبل عملية نقل 
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البيانات. للأسف تظهر مشكلة كبيرة عند الاضطرار إلى تبادل المعطيات بين أطراف غير مرتبطين بشكل مباشر. مثل حالة موقع 
تجارة الكترونية وزبون يحاول الشراء من هذا الموقع حيث تصبح عملية تبادل مفتاح التشفير هومشكلة بحد ذاته. تسمى تقنية 
التشفير المتناظر أيضا تشفير المفتاح السري. 

أكثر النماذج شيوعاً لهذه الطريقة هي التشفير القياسي للبيانات .0٤S‏ وقد تم بعدها تطوير العديد من التقنيات الأكثر أماناً منها 
التشفير القياسي المتقدم ۸۴5 المبني على خوارزمية ا2ك٠‏ ز۸ كذلك تقنية 30٤5S‏ وخوارزمية تشفير البيانات العالمية 
Blowfish y IDEA‏ ومجموعة خlyرlınjت .RC6; RC2,8C4,8C5و Rivest‏ 


التشفير غير المتمائل يتناول المشكلة الأساسية التي تشوب التشفير التماتلي وهي استخدام مفتاح وحيد. في عام 1975 قام عالمان 
هما ام0 و”جص ام1 بتطوير حل باستخدام مفتاحين مختلفين يستخدم الأول في عملية التشفير والثاني في فك التشفير. يسمى 
المفتاح المستخدم في التشفير المفتاح العام. يتم توزيع هذا المفتاح بصورة عامة عبر قنوات غير آمنة للاستخدام العام. أما المفتاح 
المستخدم لفك التشفير فيسمى المفتاح الخاص. لا يتم نقل هذا المفتاح لأنه مطلوب فقط من قبل الطرف الذي يقوم بفك تشفير 
البيانات. تكون هذه المفاتيح متصلة بشكل ضمني ومبنية على أعداد أولية كبيرة وتوابع وحيدة الاتجاه. تجعل هذه التقنية من غير 
المجدي رياضياً حساب المفتاح الخاص من المفتاح العام. 


يمكن اختراق بعض أنظمة التشفير المنية على مفاتيح بطول 64بت مثل 065 باستخدام التجريب بالقوة وذلك بمحاولة اختبار 
جميع الاحتمالات الممكنة لحين إيجاد التركيية المناسبة. 


تقنيات الأمان: الشهادات الرقمية 


توفر الشهادات الرقمية طريقة لضمان كون المفتاح العام ينتمي إلى الطرف الذي يمثله. ولكي يتحقق هذا الأمر يجب أن يتم التحقق 
أيضاً من الشهادة للتاكد من أنها تمثل الجهة المدعية (شخص أومؤسسة). 


تتم هذه العملية بالاعتماد على طرف ثالث يسمى سلطة منح الشھادات .Certificate Aں† ۸٥٣۷‏ من اهم سلطات منح الشھادات 
عالميا شركات aڻJ .Certicom «Entrust «VeriSig‏ 


تحتوي الشهادات الرقمية عادة على التالي: 
ات عل اا ات اة ا ااك ك تقض جا مات اة ضا عن محدد المصدر القياسي لمخدم 
الوب الذي يستخدم هذه الشهادة وعنوان البريد الخاص به. 
المفتاح العام المخصص لحامل الشهادة. 
اسم سلطة منح الشهادات التي أصدرت هذه الشهادة. 
مدة صلاحية الشهادة (عادة تاريخ البداية والنهاية). 
توقيع رقمي من سلطة منح الشهادات للتحقق من أنه لم تتم عملية عبث بالمناقلة. 


كذلك يملك المستخدمون خيار توقيع شهادة رقمية بنفسهم بحيث يكونون سلطة مانحة للشهادات لأنفسهم. هذا الطرف الإضافي يمكن أن 
يعتبر موثوقاً إذا كان هوالآخر موقعا بمفتاح موثوق. بهذه الطريقة يمكن استمرار متابعة الشهادة للوصول لئ السلطة الموثوقة قة الأساسية 
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التي قامت بمنح هذه الشهادة وإلا فتعتبر كامل السلسلة غير موثوقة. 


من أهم التنسيقات المعيارية لهذه الشهادات التنسيق 509.× حيث تعتبر هذه الشهادات مشهورة ضمن تطبيقات الانترنت. أما ضمن 
مجال التقنيات اللاسلكية فيستخدم نوع آخر من الشهادات الرقمية يمى AP Server WTLS Certificale‏ حیث تعتبر ھذہ 
الشهادات شهادات مختصرة عن شهادات ۷۲18 (التي سناأتي على ذكرها لاحقا ضمن هذه الجلسة) وهي نسخة مبسطة عن المعيار 
9 تم إنشاؤها لأن المعيار شهادات 509.× كبيرة لاتتناسب مع طبيعة التطبيقات اللاسلكية.تستخدم شهادات ۷1158 عادة في 
تطبيقات ۸۴عندما يريد المستعرض الصغري التحقق من هوية مخدم ۷۸۴ وتشفير البيانات باستخدام .N۲1-S‏ 


تقنيات الأمان: التوقيع الرقمي 


يُستخدم التوقيع الرقمي للتحقق من كون الرسالة قد أتت بالفعل من المرسل المدعي. يكون هذا التوقيع مبني على مبداً أن من أنشئ 
التوقيع يملك المفتاح الخاص وبحيث يمكن التحقق منه باستخدام المفتاح العام. 


يتم إنشاء التوقيع الرقمي بئلخيص الوثيقة ثم دمجها مع معلومات عنالموقع وختم زمني ومعلومات أخرى مطلوبة. 
عملية التلخيص هي عبارة عن تابع يقوم بأخذ حجم كيفي من الوثيقة (الرسالة) وتوليد خرج بحجم ثابت يدعى الطبعة. يتم بعدها تشفير 
هذه المعلومات باستخدام مفتاح خاص من قبل المرسل باستخدام خوارزمية غير متناظرة مناسبة. تسمى الكتلة المشفرة الناتجة التوقيع 


اللكتروني. 


تكون طبعة الرسالة الذي تم حسابها عبارة عن قيمة تمثل الحالة الراهنة للوثيقة. فإذا تم تعديل الوثيقة أوالعبث بها بأي طريقة ستتغير 
قيمة هذه الطبعة. 


بدمج هذه الطبعة في بنية التوقيع الالكتروني يصبح بإمكان المستقبل اكتشاف أي عملية عبث بالوثيقة منذ إنشاء التوقيع الالكتروني. 
البنية التحتية للمفتاح العام: 


البئية التحتية للمفتاح العام أوما يمى ب ۶1 هو التعبير الذي يصف منظمة كاملة من النظم والقواعد التي تعراف نظام أمان وحيد. 


عرف مجموعة عمل 509.× 181۴ البنية التحتية للمفتاح العام على أنها مجموعة الكيانات الصابةء والبرمجيات»ء والأشخاص» 


والإجراءات اللازمة لإنشاءء وإدارة وتخزین»› وتوزیع»؛ ورفض الشهادات المبنية على تعمية المفتاح العام. 


ن¿ ۴K‏ المكونات التالية: 
سلطات مانحة للشهادات مسؤولة عن عملية إصدار أورفض الشهادات. 
سلطات تسجيل مسؤولة عن ربط المفاتيح العامة مع هوية حامليها. 
حاملوالشهادات الذين تم إصدار شهادات لهم والتي بإمكانهم استخدامها لتوقيع الوثائق الالكترونية. 
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- موضع تخزين لتخزين معلومات الشهادات الصادرة وتلك التي تم إبطالها أورفضها. 
- سياسة أمان تحدد الأمان كتوجه أساسي للمنظمة. 


البرتوكولات الرئيسية المستخدمة في النقل الآمن للبيانات: 


:(Secure Socket Layer) SSL janî! برتوكول طبقة المقبس‎ 


يعتبر هذا البروتوكول من البروتوكولات الهامة المستخدمة خاا على الانترنت. تم تطويره من قبل شركة Netscape‏ لتأمین جلسات 
آمنة خاصة وهويُستخدم بصورة أساسية فوق البروتوكول ۶ علماً آنه یمکن أن یستخدم فوق بروتوکول اُخری منھا ۴۲۲. 


يُستخدم هذا البروتوكول مزيج من الخوارزميات المتناظرة وغير المتناظرة لرفع الأداء. 


هناك أربع مراحل أساسية ضمن جلسة SS‏ هي: 
المصافحة والتفاورض على الشيفرة: حيث ينفق كل من الزبون والمخدم على الخوارزميات أوالشيفرة المستخدمة. 
التحقق من الهوية: حيث يتم التحقق من هوية المخدم (وبشكل كيفي الزبون) باستخدام شهادة رقمية. 
تبادل المفتاح: يقوم الزبون بإنشاء مفتاح سري ويرسله إلى المخدم باستخدام تشفير المفتاح العام. يقوم المخدم بفك تشفير 
الرسالة باستعمال المفتاح الخاص. بعد هذا سيتمكن الزبون والمخدم بالاتصال حتى نهاية الجلسة وإرسال المعلومات مشفرة 
باستخدام المفتاح السري. 
شال :انات التطدق 2 ما أن بت اسفن خلسة أمخة تسافا يمكن أن يتم تناقل البيانات المشفرة بين الزبون والمخدم. 


يمكن استعمال 8S1‏ من قبل العديد من الأجهزة المحمولة. 

يمكنك تحديد كونك تستعمل 851 أم لا من ظهور اسم البرتوكول م))1 عوضاً عن ص11 في بداية محدد المصدر القياسي. 

إن تشفير البيانات ضمن البرتوكول أكثر فعالية من تشفير البيانات فقط وإرسالها باستخدام 1۲۲۴ لأن عملية التشفير ضمن البرتوكول 
تقوم بتشفير البيانات على مستوى الحزمة أما إذا قمت بتشفير البيانات ثم إرسالها باستخدام البرتوكول فلن تستتطيع فك التشفير لحين 
وصول جميع الحزم الخاصة بالرسالة المرسلة. 


:(Transport Layer Security) TLS Jill بروتكول أمان طبقة‎ 


يعد 118 الجيل الجديد من برتوكول SS]‏ حيث يتكون من طبقتين: الطبقة الأدنى هي طبقة بروتوكول السجل 01ع0إoإp Record‏ 
والذي يتوضع عادة فوق طبقة بروتوكول نقل ذواعتمادية عالية کبروتوکول .۲٣۲‏ 

أما الطبقة العليا من بروتوكول 11S‏ فهي طبقة بروتوكول المصافحة keهطءلمه1.‏ توفر هذه الطبقة الاتصال الآمن باستخدام التحقق 
من الهوية الذي يستعمل التعمية المتناظرة» والتفاوض على المفتاح السري» وتزويد تفاوض ذواعتمادية عالية. 

كما هي الحال في S81‏ ف 1S1‏ مستقلة عن الشيقرة أي تستطيع استخدام طيف من الشيفرات. 

تكمن الأهداف الأساسية وراء استخدام 115 في أمان التشفيرء وقابلية التشغيل البيني» وإمكانية التوسع. 
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برتوكول أمان طبقة النقل اللاسلكي :۷11S‏ 


58 هي طبقة الأمان المعرفة ضمن المعيار ۷4۴. ويعمل فوق llبرgتgكJg Transport Protocol Layer‏ مما يجله متاس 
للعديد من البروتوكولات اللاسلكية الأخرى. 

يشابه هذا البروتوكول» البروتوكول 118 ولكن تم تحسينه للعمل بشكل أفضل على الشبكات ذات زمن التأخير العالي وعرض الحزمة 
الضيق. كذلك يضيف هذا البروثوكول ميزات دعم حزم البيانات وأمثلية عملية المصافحة وتحديث المفتاح. كذلك يدعم استخدام شهادات 
858 ااتخفق من الهرية من طرف لمكن 


:(IPSec) IP Security Jgكgتgرڊ‎ 


يختلف بروتوكول 1۲56٥‏ عن البروتوكولات الباقية في أنه لا يعمل في طبقة التطبيق وفي حين تعمل بروتوكولات ا؟؟S»‏ 18ء 
58 لتأمين اتصال آمن على شبكة غير آمنة يتوجه 156٥‏ إلى جعل الانترنت بحد ذاتها آمنة. 

يساعد 1۴56٥‏ هذا في توفير خدمات تحقق من الهوية»ء سلامة البيانات» والخصوصية على طبقة حزمة البيانات. 

استهدف 1۶56٥0‏ بصورة أساسية من بين الأجهزة المحمولة زبائن أجهزة الحاسب المحمول. ولكن بدأت وبشكل سريع أنواع الأجهزة 
المحمولة المختلفة تدعم الشبكات الافتراضية الخاصة المبنية على ٤ع؟1۲.‏ 

سز قفار اا ا الر رل وک رن 186 لى بم 188 كز ون امعان الفا به من ال ايشا 
معرفة أن ع1۲5 یدعم 1٤۲/1۲‏ ولا یدعم .WAP‏ 


مقاييس أمان أخرى 


يجب الأخذ بعين الاعتبار أيضاً عند تطبيق الحل المحمول العديد من مقاييس الأمان الأخرى التي تستخدم كتقنيات لرفع سوية الأمن 
العام للنظام. أهم هذه التقنيات هي: 


الجدران النارية : 

تشكل هذه الجدران کارا في الشبكة بين ما هوخاص وعام. وجدار النار عبارة عن مجموعة من البرمجيات التي عادة ما يتم 
توضيعها على مخدم عبّارة منفصل تكون وظيفته الأساسية تقييد الوصول إلى مصادر الشبكة الخاصة من المستخدمين في الشبكات 
الأخرى. عند تثبيت إمكانية الوصول إلى المؤسسة عبر الانترنت سيكون من الضروري تركيب جدار ناري لحماية المصادر ضمن 
المؤسسة وأحيانا للتحكم بالمصادر التي يستطيع مستخدموشبكتنا الوصول إليها.بالنسبة للتجهيزات المحمولة التي تمتلك اتصال دائم 
يشكل وجود جدار نار شخصي على الجهاز المحمول فكرة جيدة. 


الشبكات الافتراضية الخاصة ٣×١‏ ۷: 

تسمح شبكات ۷۴١×N‏ بتحويل شبكة عامة (عادة الانترنت) إلى شبكة خاصة. تمكن هذه التقنية الأشخاص الذين يعملون عن بعد من 
الاتصال بشبكة المؤسسة بطريقة آمنة عبر الانترنت. 

قل وک فاخا الول جال حرا عا رة ورل ال ن اق د ك 6 
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لتجاوز مشاكل الأمن في شبكات ١4اW.‏ 


التحقق من الهوية المبني على معاملين: 

عادة عند التعامل مع المناقلات المالية أوذات الطابع الحساس تكون الحاجة ماسة إلى آلية تحقق من الهوية على السوية المناسبة.تتلخص 
هذه الطريقة في حاجة المستخدمين إلى المرور في عملية تحقق مزدوج من الهوية عادة ما يكون باستخدام كلمة مرور مثلاً إضافة إلى 
امتلاك المستخدم لبطاقة تقوم بتوليد كلمة سر لمرة واحدة عند كل دخول. دمج هذين المعاملين يجعل من الصعب جداً على الأشخاص 
غير المرخصين بالوصول إلى النظام. 


المقاييس الحيوية: 

حى اتتام التق من هري المي جلى عاطين ون السفتر قن الرضرل لى اطا 

للتخلص من هذا يمكن استبدال كلمة السر بنموذج أقوى من التحقق من الهوية وهوذلك المبني على المقاييس الحيوية مثل تلك التي تعتمد 
البصمةء التعرف على شكل الوجهء شكل قزحية العين» التعرف على الصوت...إلخ مشكلة هذه الطرق أن اعتماديتها غير عالية ففي 
الكثير من الأحيان تودي إلى ما يسمى الرفض الخاطئ وعدم السماح لأشخاص مرخصين بالدخول. 


سياسة الأمان : 

أخزا و نن آخزا لا بد من اعتماد سياسة أمان ضمن الشركة أوالمؤسسة. إن مقاييس الأمان المتبعة التي استعرضنا بعضها هي 
انعكاس لسياسة الأمان التي يجب أن تقوم بوضع النقاط الرئيسية لكل نواحي الأمان في المؤسسة بما يتضمن التقنيات وكيفية استخدامها. 
حتى في حال اعتماد المؤسسة حلول أمنية متفوقة تقنياً سيظل النظام غير آمن إذا لم يتبع المستخدمون تعليمات الأمان الضرورية. 


يجب دائماً أن نتذكر بأن المتطفلين يهاجمون النقطة الأضعف في النظام والتي أحياناً لا تكون الجانب الثقني ولكن المستخدمون أنفسهم. 
مان برتوکول W۸۶۴‏ 


لطالما تعرض بروتوكول ۷۸۴ للانتقاد بسبب ضعف تغطيته للنواحي الأمنية. سنتعرف في هذا الجزء من الجلسة على المشاكل 
الأمنية في برتوكول ۷۸ وكيفية تجاوزها. 


لا بد من تغطية النقاط التالية في بنيان الأمان الخاص بالنسخة :W۸۴1.×‏ 


:TLS 
أمان طبقة النقل والمعروف بالقناة الآمنة. يقوم بالتعامل مع الاتصال نقطة إلى نقطة بين الزبون اللاسلكي ومصدر البيانات في‎ 
المؤسسة. تتخلل هذه العملية عملية الاتصال عبر قنوات لاسلكية وسلكية. في ۷0۸۴ يتم تشفير البيانات أثناء نقلها عبر الأثير باستخدام‎ 
أو118. يقود هذا الاختلاف إلى أحد المشاكل الأساسية في أمان‎ S81 وعبر الأسلاك باستخدام بروتوكولات مثل‎ ۷118S بروتوكول‎ 

۴ . قبل الدخول في تفصيل المشكلة سنتعرف بشكل أوسع على البروتوكول ۷118S‏ وميزاته. 


تم تطوير بروتوكول 0118S‏ ليغطي حاجة بيئة الشبكات اللاسلكية بمواصفاتها الخاصة كضيق عرض الحزمة»ء والتأخير العالي على 
الشبكة لتكون البديل اللاسلكي لبروتوكول 118. والذي لا يمكن استخدامه بفعالية في البيئة اللاسلكية. 
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تمثل النقاط التالية أهم المميزات التي تمت إضافتها إلى برتوكول 11S‏ والتي لا يقدمها 118: 
- دعم خوارزميات تعمية مختلفة. في حين تدعم S1؟S‏ و118 تشفير RSA‏ تدعم .ECC, DH, RSA رıفشت W1LS‏ 
تعريف شهادة مفتاح عام مدمج وشهادات ۷118S‏ وهي أكثر فعالية من نسخة شهادات 509×. 
دعم حزم بيانات .0D۴‏ يتناول هذا عدة مناطق من البروتوكول ابتداءا من تشفير البيانات وحتى إدارة الرسائل» تكرارها 


وترتيبها. 
خيار قخيت المقاح السققدم رت ب التقارض تبات متي على مدرك المقاع الخدم وفك تبجعا تحت الرسائل المرساة 


مجموعة أوسع من التحذيرات بما يضيف وضوح أعلى عند معالجة الا×طاء. 
تحقيق أمثلية المصافحة مما يقلل من عدد الدورات المطلوبة لتحقيق هذه العملية بشكل يناسب البيئة ذات التأخير العالي 
للشبكات اللاسلكية. 


بالإضافة إلى هذه الميزات تقدم W118‏ ثلاث سويات من التحقق من الصحة بين الزبون والعبّارة هي التالية: 
:C1ss 1 ۷6S‏ تفاعل بين الزبون وعبارة ۷۸٣‏ بدون تحقق من الهوية. 

.۷ 118 يقوم المخدم بإظهار هویته لازبون باستخدام شهادة‎ : C1458 [m-8 

:C1ss ][ 5S‏ يقوم كل من عبارة ۷۸۶ والزبون بالتحقق من هوية الطرف الآخر. 


يستخدم هذا النوع من التحقق من الهوية باستخدام البطاقات الذكية.فمثلاً يمكن ل )81M(‏ في نظام 65۷ تخزين معلومات 
التحفق من الصحة: 


الثغرة في برتوكول ۷۸۲ 


لسوء الحظ وبالرغم من تقديم 11S‏ ۷ للعديد من المميزات التي تضاهي برتوكول © بالنسبة للنقل الآمن للمعلومات لاسلكياً إلا 
أنه تسبب بمشكلة أساسية. 


تتلخص المشكلة في ضرورة استخدام WLS‏ وا11 ضمن نفس البنيان الخاص ب .WAP°‏ ففي مرحلة معينة هناك حاجة 
للترجمة بين البرتوكولين. من هذه النقطة وليس من برتوكول 0118 نفسه تبرز مشكلة تغرة أمنية. 


إن عملية الترجمة تلك تتم على عبارة ۷۸۶ حيث يتم استخدام ۷1158 بين الجهاز المحمول والعبّارة وبروتوكول 115 بين 
العبّارة ومخدم المؤسسة. في هذه المرحلة وضمن عبّارة ۷۸۴ تتم عمل فك تشفير للمحتوى المُشفر باستخدام ۷118S‏ وإعادة 
تشفير ه باستخدام البروتوكول 118 وأثناء عملية فك وإعادة التشفير تلك تتواجد المعلومات بصيغة نص صريح. مع أن الزمن الذي 
تبقى فيه المعلومات بصيغتها الصريحة أصغري ومع أن العبارة غير موجودة ضمن النطاق العام ولكن تظل هذه الثغرة نقطة 
لايُستهان بها في موضوع الأمان ضمن المعيار ۷۸۴ . 
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هناك خياران للتعامل مع ثغرة W۸۲۴‏ : 

- قبول وجود نقطة الضعف تلك على العبّارة وبذل كل الجهود لحماية العبّارة باستخدام الجدران الناريةء وآليات المراقبة وتشديد 
سياسة الأمان ما أمكن. 

- نقل عبارة ۷4۴ إلى داخل نطاق المؤسسة وإدارتها ذاتياً. 


الاختيار بين هذين الحلين هوعبارة عن قرار يرتبط بالمؤسسة وهوعبارة عن مقايضة بين استهلاك مصادر إضافية لإدارة تطبيق عبارة 


4P‏ ضمن المؤسسةء والتهديدات الأمنية المحتملة على بيانات المؤسسة. لحسن الحظ تم إيجاد حل لهذه المشكلة ضمن المعيار 
WAP2.x‏ 


:WAP2.x 


هناك العديد من الميزات الجديدة التي حملها المعيار ×.۴2 ۷۸ ولكن كان الأكثر أهمية منها دعم بروتوكولات الانترنت القياسية. قاد 
هذا إلى استخدام برتوکو لات مثل ۲۲۶ 83» ٠1۳۲‏ 1۲ وتمكين استخدام البرتوكول ۲18 للنقل الآمن للبيانات. 


نظرأ لزوال الحاجة لاستخدام ۷118S‏ أصبح بإمكان بروتوكول واحد هو118 أن يستخدم من الجهاز الزبون إلى مخدم المؤسسة 
وبالتالي الحصول على اتصال من نهاية إلى نهاية حقيقي وآمن والتخلص ثغرة ۷۸۴ تماماً. 


الأمان على مستوى التطبيق 


مع کل الانتباه إلى ثغرة ۷۸۶ وبروتوكول 58 ینسی المطورون غالباً الأمان علی مستوی التطبيق. 


يعتبر الأمان على مستوى التطبيق ضروري في موضعين: 
1- عندما يكون الأمان مطلوبا بما يتجاوز نقاط النهاية لبرتوكول 118. 
2- عندما يكون المطلوب الوصول إلى المحتوى التقديمي وليس إلى بيانات المؤسسة. 


يتلخص السيناريو الأول الذي يمكن الحديث عنه في استخدام تقنيات تزودها ا١۷.‏ بشكل عام» يتم تعيين لإعدادات الافتراضية إلى 
أعلى درجة أمان. فيما يلي بعض النقاط الواجب ملاحظتها: 
- يجب على كل بطاقة ا۷١۷‏ تطلب الوصول إلى معلومات حساسة إسناد القيمة عuإ٠‏ إلى الواصفة ١٤إعfع]send‏ 
ضمن التأشيرة <20>. 
يجب على النص البرمجي الذي يقوم بمعالجة الطلبات الخاصة بالمعلومات الحساسة التأكد من محدد المصدر القياسي 
المعين في الترويسة REFER٤R‏ ضمن طلب 1١۲۴‏ للتأكد من أن الطلب الذي تتم معالجته قادم من نطاق 


صدیق . 
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- يجب استخدام البرتوكول 1۲۲۲8 وتمكين تحقق الهوية الأساسي وعدم الاعتماد على مصدر الاتصال فقط كمعرف 
الهاتف مثلاً في حال الاتصال عن بعد. 


يتلخص السيناريوالثاني الذي يمكن الحديث عنه في أم¡WMLScr AP],‏ t0مypا€.‏ باستخدام التابع 1٥×٤‏ "١ع1ء‏ ضمن الواجھة 
البرمجية 0امر۲٤‏ يمكن إنشاء توقيع رقمي يفتح الباب للبنية التحتية للمفتاح العام ۴)1 لإدارة وإصدار شهادات مفتاح عام. تسمح هذه 


التقنية بتشفير نهاية إلى نهاية بين مزود الخدمة والزبون. 
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الخدمات المرتبطة بالموقع 8S‏ 


الكلمات المفتاحية: 
موقع» إحداثيات»› تتليث»› محطة» خدمات 


ملخضص: 
سنتعرف في هذه الجلسة على ماهية الخدمات المرتبطة بالموقع وما هي الأجيال التي مرت وتمر بها هذه الخدمة. كما سنتعرف على 
أهم التقنيات المستخدمة في تحديد الموقع ومدى دقتها. وسنتطرق فيه إلى الحديث عن أنظمة المعلومات الجغرافية. 


أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على: 
© مفهوم الخدمات المرتبطة بالموقع والأجيال التي مر بها. 
€ أهم التقنيات المستخدمة في تحديد موقع الأجهزة المحمولة. 


€ أنظمة المعلومات الجغرافية وعلاقتها بالخدمات المرتبطة بالموقع. 
© ملاحظات حول تطوير التطبيقات المرتبطة بالموقع. 
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الخدمات المرتبطة بالموقع (18Sا)‏ 


تعطي إضافة المعلومات المتعلقة بالموقع بعداً هاما جديداً للعديد من الحلول. إن التطبيقات التي تأخذ الموقع بعين الاعتبار تزيد 
بشكل كبيرمن فعالية المستخدم وذلك بتقديم وصول مخصص للبيانات ليس مبنياً فقط تفضيلات المستخدم بل على موقع وجود 
المستخدم أيضا بسا يقل تخصيص المخثوى إلى دزجة جديذة توقر فواك لا تحصى المستملك و لتظبيقات المزسسة. 


الخدمات المبنية على الموقع : ماذاء لماذا ومتى: 

يتفق المحللون» ومزودوالخدمةء والمستهلكون على شيء واحد وهوأن الخدمات المبنية على الموقع هي خدمات ذات فائدة عالية 
بالنسبة لمستخدمي الأجهزة المحمولة. 

تتدر ج حاجات الأشخاص لقدرات التطبيقات المرتبطة بالموقع من حاجات الأمان وحتى حاجات التجارة المحمولة. 


ماذا؟ باختصار الخدمات المبنية على الموقع هي عبارة عن تطبيقات تستفيد من معلومات الموقع لتؤمن الخدمات المناسبة. 


لماذا؟ يمكن أن تتدرج هذه الخدمات من إيجاد أقرب محطة وقود إلى الحصول عن معلومات الانتقال بین نقطتین ۸ و8 
أومعلومات الموقع لأقرب مركز طوارئ. 

قد تقوم أنظمة أخرى مرتبطة بالموقع بإرسال رسائل تنبيهية إلى جهاز محمول حول تخفيضات على الأسعار في مركز ما لدى 
المرور بقربه. 


متى؟ يتدرج السوق في هذه المرحلة من الجيل الثاني إلى الثالث وتقود عملية التحول هذه دواعي مرتبطة بالأمان أوالتجارة. 


هناك ثلاث أجيال أساسية للخدمات المرتبطة بالموقع : 


الجيل الأول: كانت هذه التطبيقات تتطلب من المستخدم إدخال المعلومات حول موقعه إلى الجهاز. يمكن أن يكون أحد الأشكال 
الممكنة للإدخال لهذه المعلومات على شكل عنوان بريدي واعتمادا على هذه المعلومات يقدم التطبيق معلومات مخصصة كاتجاهات 
القيادة والمطاعم القريبة..إلخ. 

الجيل التاني: يمكن لهذه التطبيقات أن تحدد معلومات الموقع دون الحاجة إلى تدخل مستخدم الجهاز المحمول. يكون هذا الموقع 
دقيقاً بفارق مسافة لا تزيد عن عدة كيلومترات. تقدم تطبيقات هذا الجيل خدمات مشابهة لما تقوم به تطبيقات الجيل الأول. 

الجيل الثالث: يمكن لهذه التطبيقات الحصول بشكل أدق على معلومات الموقع وتستطيع تزويد خدمات اعتماداً على تلك المعلومات. 
يمكن لهذه التطبيقات تقديم تحديثات شبه آنية عن الخدمات المحيطة كمعلومات التوجه والطرق ومعلومات المتابعة. تقدم هذه 
التطبيقات مز ايا عديدة ومفيدة للمستخدم لكن ما يزال البعض قلقا بخصوص قضاء مثل هذه التطبيقات على الخصوصية. 
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التطبيقات المرتبطة بالموقع 


سنستعرض أهم التطبيقات التي تستتمر فيها هذه الخدمات وماهي القيمة التي تعود بها على المستهلكين» الشركات والتطبيقات الحكومية. 
من المتوقع أن يتوسع تبني هذه التطبيقات مع إدراك المستهلكين والشركات الفائدة التي تمنحها. ولكن قبل أن يحدث هذا لا بد لأ 
تطبيقات 188 أن تصبح دقيقةء سريعة وسهلة الاستخدام. 


في ما يلي أهم وأكثر الاستخدامات شيوعاً لهذه التطبيقات : 


خدمات الطوارئ: 

في حالات الطوارئ يمكن للمستخدمين الاتصال بمركز طوارئ ليتم تحديد موقعهم وإيصال المساعدة إليهم. وهذه الخدمة هي أساس 
خدمة E911‏ المتوفرة في أجزاء من أمريكا الشماليةء كما تستخدم هذه الخدمة بشكل عام لمساعدة العربات المعطلة والتي تواجه مشكلة 
ا 


معلومات السير المرورية: 
تقوم بعض تطبيقات 185 بالمساعدة على تحديد الموقع الحالي للمستخدم وموقع وجود اختناق وتقوم على أساس هذه المعلومات 
باقتراح المسار الأفضل لتجاوز الاختناق المروري. 


التجوال: 
يندرج تحت هذا التصنيف العديد من التطبيقات ولكن كلها تتركز على الإجابة عن السؤال : كيف أستطيع أن أصل من النقطة "أ" إلى 
النقطة "ب" أوعن سوال أكثر تعقيدأ: ما هوالمسار الأمثلي الواجب اتباعه أثناء عملية توزيع منتج على عدة مراكز؟ 


إدارة الخدمات الميدانية: 
تجعل هذه الخدمة من الممكن تتبع منتدبي العملاء في الخدمات الميدانية بحيث يتم تكليف أقرب عميل إلى طلب الخدمة الأقرب إلى 
موقع وجوده. تفيد هذه الخدمة بشكل كبير العاملين في مجال الخدمات الطارئة كعربات الشرطة والإسعاف والإطفاء. 


إدارة الأساطيل: 
باستخدام 185 يصبح من الممكن تتبع موقع أساطيل تسليم المنتجات مثلاً وتقدير وقت الوصول التقريبي. 


تتبع الممتلكات: 
هذه الخدمة شبيهة بالخدمة السابقة ولكنها موجهة لتتبع الممتلكات كالطرود والتجهيزات المحمولة أوالأمتعة ذات القيمة العالية. 


الإعلانات اللاسلكية: 

يمكن للمستخدمين التسجيل في خدمات تعلمهم بمعلومات متعلقة بمنتج معين خلال وجودهم في منطقة معينة. فعلى سبيل المثال عند 
الاقتراب من مركز تسوق يمكن أن يتم إعلام المستخدم أن المحل المفضل لديه يعرض تنزيلات. تتطلب هذه الخدمة عادة معلومات 
دقيقة جدا عن الموقع لذلك تحتاج إلى فترة لتنتشر بصورة فعلية. 
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تمكن هذه الخدمة مستخدم الجهاز المحمول من إيجاد خدمة أومكان ما في المنطقة التي يتواجد فيها كالعثور مثلاً على مطاعم أومحطات 
وقود أومساحات لعب غولف. كما يمكن ربط متل هذه الخدمات بتطبيقات خاصة بالحجز والشراء لتسهيل التجارة المحمولة. 


متابعة موقع العربات أوتوماتيكياً: 
أحد الخدمات الشائعة التي تم تطبيقها مؤخراً هي خدمة متابعة العربات حيث يمكن بهذه الطريقة تحديد موقع العربات المسروقة 
واستعادتها. 


الخرائط : 
يتوفر ضمن العديد من العريات مؤخراً خدمات خرائط تمكن من الحصول على معلومات حول الموقع الحالي وخرائط تفصيلية حول 
المرافق المحيطة ومؤخرأ تم دمج هذه الخدمات مع خدمات التجوال. 


يمكن أن يتم تزويد معلومات عن الطقس بحسب موقع المستخدم ولكن هذه المعلومات ستتعلق دقة المعلومات بدقة أقرب محطة رصد 
تقنيات تحديد موقع الأجهزة المحمولة 


قبل إنشاء الحلول المرتبطة بموقع الأجهزة المحمولة لا بد من أن نجد طريقة لتحديد موقع هذه الأجهزة. تتوفر العديد من التقنيات التي 
تم اعتمادها والتي توفر هذه المعلومات. 


إن قرار اختيار أحد هذه التقنيات ليتم استخدامها هوقرار يبنى عادة على موازنة بين عاملين هما الكلفة والدقة. فمع ارتفاع الدقة 
المطلوب الحصول عليها ترتفع الكلفة المتوقعة للحل. 


عادة ما تتوزع هذه الكلفة بين مستخدمي الأجهزة المحمولة ومزود الخدمة اللاسلكية. يجب على المطورين عادة الاعتماد على 
ا ره امن العار المهرل رمن و الك ال رضت هه ارات و رة ار لي ا 
تحديد معلومات الموقع. 

في معظم الحالات تتعلق دقة تحديد الموقع بنوع تقنية تحديد الموقع المتبعة. 


هناك حلول مبنية على الشبكة يمكن تطبيقها من قبل مزود الخدمة اللاسلكية لتحديد معلومات الموقع للتجهيزات المحمولة القديمة 
والحديثة.تعتبر هذه الحلول مجدية من حيث الكلفة ولكن الدقة التي تقدمها منخفضة تتراوح بين مئات الأمتار وحتى بضع كيلومترات 
وذلك بحسب الحل. 

أما الحلول المبنية على التجهيزات المخحمولة نفسها فتستطيع تحسين الدقة بشكل كبير ولكنها بالمقابل تؤثر بشكل كبير في رفع الكلفة 
سواء بالنسبة للجهاز المحمول نفسه أوبالنسبة لمشغل الشبكة.باستخدام تلك الحلول يمكن الحصول على معلومات الموقع بدقة تصل 
حتى بضعة أمتار أوحتى أقدام من موقع وجود المستخدم. 
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في معظم الحالات يشكل الحل المختلط التقريب الأفضل وذلك للحصول على حل بدقة معقولة وبكلفة مقبولة. 


يعتبر الهدف الأساسي لجميع تقنيات تحديد الموقع تحديد الإحداثيات ,× للجهاز المحمول وسنحاول خلال الشرائح التالي استعراض 
الطرق الأساسية لإتمام هذا العمل. 


تقنيات تحديد موقع الأجهزة المحمولة 
الحلول المعتمدة على الشبكة 


يُعتبر استخدام المحطات الثابتة التي تؤلف حامل الشبكة اللاسلكية إحدى الطرق لتحديد موقع زبون محمول. يحتوي كل من هذه 
المحطات على جهاز اعتراض راديوي لاستقبال الإشارات من الأجهزة المحمولة. 

بأخذ الإشارة من محطة واحدة أوأكثر يمكن تحديد موقع الجهاز المحمول. بصورة عامة كلما ازداد عدد المحطات المستخدمة كلما تم 
الحصول على معلومات أدق حول الموقع. 

يمكن للحل المتعمد على الشبكة العمل مع التجهيزات المحمولة الموجودة في الاستخدام وجعلها خطوة أولى لتزويد معلومات الموقع. 


مُعرف الخلية: 

تعتبر هذه الطريقة من أبسط الطرق لتزويد معلومات الوقع وأكثرها جدوى من حيث الكلفة. وهي ببساطة تحدد أي الخلايا اللاسلكية 
يستخدمها التجهيز المحمول وتقوم بالإبلاغ عن موقعها. ولما كانت المحطة الأساسية لكل خلية ثابتة فإنه يمكن تحويل معرف الخلية إلى 
معلومات موقع للجهاز المحمول. 

يكمن الجانب السيء لهذا الحل في أن الموقع الدقيق للجهاز المحمول ضمن مجال الخلية غير محدد. 

توفر هذه الطريقة معلومات بفارق حتى 2-1 كيلومتر. تعتبر هذه المعلومات مقبولة لأخذ فكرة عامة عن الموقع ولكنها لا توفر تلك 
المعلومات الكافية لخدمات الطوارئ أوالتوجيه على الطرق أوالإعلانات. 

لحسن الحظ هناك طرق أخرى لتحسين الدقة التي توفرها طريقة محدد الخلية. 

بعض الخلايا مقسم إلى قطاعات ويقلل المساحة الكلية وهذا ما يمكن أن يقلل الخطاً في تحديد الموقع حتى الثلث. 


فی ع د ا ق ا ق ق ف ع ا 
وبالتالي تقليل الخطاً في تحديد الموقع بشكل كبير. 

اتر ف لطر فة ركا عضن ففة ااا فى كس مرق متكا مرك اة 

اف تن رفاك الخسر ل على مامات ۲4 أن ان لون درن الرشر ن ل كر ت رق ار 066 ر 
EE E E E E e O‏ و اکر کا ا و 
ب0٥۱۴‏ للحصول على معلومات 1۸ مع معلومات محدد الخلية. 


يوضح الشكل التالي الآليات المستخدمة التي ناقشناها ضمن طريقة مُعرّف الخلية: 
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Cell Identity Cell Identity 
with an ormnisector cell with a three-sêector cel| 


Cell Identity Cell Identity 
with timing advance with a three-sector cell 
and timing advance 


تسمى هذه الطرق عند تركيبها معاً CG1-١۸‏ وهي اختصار لمعرف الخلية العام-السيق الزمني يمكن لهذا التقريب أن يقودنا إلى 
نتائج بدقة بين 100 إلى 200 متر. وهي عبارة عن دقة جيدة جداً نسبة إلى بساطة هذه التقنية التي لا تتطلب أي تحديث في الأجهزة 
المخفولة: 

لا بد من الذكر أيضاً بأن هذه الطريقة أكثر فعالية ضمن المدن نظراً لكثافة المحطات في المناطق المأهولة. 


تقنية زمن الوصول 10۸ 


حتى عند اعتماد تقنية السبق الزمني مع معرف الخلية لا نحصل على الدقة الكافية للعديد من التطبيقات والخدمات التي قمنا 
باستعراضها في بداية الجلسة. 

التقريب الآخر في هذا المجال يدعى تقنية زمن الوصول ۲0۸ أوفرق زمن الوصول ۲۲0۸. 

يمكن لهذه الثقنية أن تحسن بشكل كبير دقة تحديد الموقع. بدلاً من استخدام محطة واحدة لتحديد موضع الجهاز المحمول ستخدم 1۸0 
رمات ت جما من تلات مخظات آر أن تمل هذه الطرية بج الجهان النعرل برل فار ك اسالها حن جخ المحطات 
ضمن مدى الجهاز. تقوم كل محطة بعدها بحساب الزمن الفاصل بين إرسال الرسالة واستقبالها وليكن لثلاث محطات مثلاً 
(۲1,2,13) يجب أن تكون هذه الأزمان دقيقة جداً تتطلب كون الوقت في جميع المحطات يخضع لعلمية مزامنة. وهذا ما يتطلب إما 
نظام 6۶8 أوساعة ذرية وكلا الحلين يعتبر مكلفا كما نعلم. 
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بما أن الإشارة تتحرك بسرعة ثابتة فإنه سيصبح بالإمكان تحديد مسافة الجهاز المحمول عن المحطة. ولكن المسافة المحددة من خلية 
واحدة ليست ذات فائدة ولكن باستخدام المعلومات من ثلاث محطات يمكن تحديد مكان الجهاز المحمول نسبة إلى مواقع المحطات 
وبعدها يمكن ترجمة الإحداتيات النسبية للجهاز نسبة إلى المحطات إلى إحداتيات عامة تحدد الموقع. 

لا بد هنا من التنويه إلى أن استخدام تقنية 104 عملية جداً في الشبكات التي تعتمد تقنية ۸4/05142000 K0M‏ لأن هذه الشبكات 
مزامنة منذ البداية ولا تحتاج إلى أي ساعة ذرية أو ۴8 6. الشكل التالي يبين استخدام تقنية زمن الوصول لتحديد الموقع 


تقنية زاوية الوصول ۸0۸: 


تعمل هذه التقنية بشكل مشابه لتقنية 104 ولكن عوضاً عن استخدام الزمن اللازم لإشارة يطلقها الجهاز المحمول للوصول إلى ثلاث 
محطات تستخدم هذه التقنية الزاوية أتت منها الإشارة إلى المحطة. بمقابلة هذه المعلومات من ثلاث محطات على الأقل يمكن تحديد 
موضع الجهاز المحمول. 

تستخدم بعض الأنظمة تقنية زاوية الوصول مع تقنية زمن الوصول للحصول على دقة أعلى. 


الحلول المبنية على الجهاز المحمول نفسه 


عندما يكون المطلوب الحصول على دقة أعلى في تحديد الموقع لا بد من استخدام الحلول المبنية على الجهاز المحمول نفسه. 

في هذه الحلول يشترك الجهاز المحمول بصورة أساسية في عملية تحديد الموقع. تسمح دقة هذه الحلول بتقديم خدمات الجيل الثالث من 
85 والتي تتطلب تحديد موقع دقيق. 

يعتمد الحلان الذين سنقوم بعرضهما على نفس الطريقة لحساب الموقع ولكن الاختلاف الأساسي بينهما یکمن بأن ۳-01۲ تعتمد على 
المحطات الأرضية في حين تعتمد 6۶S‏ على الأقمار الصناعية. 


التقنية المحسنة للاختلاف الزمني :)E-015(‏ 
إن تقنية 5-010 تعمل بشكل مشابه لمبداً عمل 104 ولكن يتولى الجهاز المحمول حساب الزمن بدلا عن المحطة. تعتمد هذه التقنية 
ى ساب الزمق اللار ااقارة القاسة من محطة فى كاين جقر فين مكافن. بتكل يهاز العسرل المحطة اة ااتي رمل 
معها ما يسمى ب ل1۷ أووحدة قياس الموقع. 
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للحصول على موقع دقيق يجب أن تشترك المعلومات من ثلاث محطات في عملية الحساب تلك. لتنجح هذه التقنية يجب على المحطات 
إرسال التوقيت بشكل دقيق إلى الجهاز المحمول. باستخدام هذا التقريب» يجب إرسال جميع الإشارت في نفس الوقت لأن مستخدم 
الجهاز المحمول قد يكون في حالة حركة أثناء القياس وهنا يبرز دور ل11 حيث تزود الأخيرة مصدر توقيت دقيق من أجل عملية 
القياس للتأكد من دقة المعلومات. 

ما أن تتم عملية أخذ القياسات حتى يقوم الجهاز المحمول الذي يدعم تقنية 8-015 بتسجيل فرق الزمن من المحطات الثلاثة. عندها 
يمكن حساب المسافة بين الجهاز المحمول والمحطات وذلك بمقارنة فرق الزمن بين قياسات الزمن.يمكن تحويل فرق الزمن إلى مسافة 
لأن الإشارة تتحرك بسرعة ثابتة. بعد الحصول على المسافات يمكن الحصول على الموقع النسبي حيث يمكن لهذه العملية أن تتم على 
الجهاز المحمول نفسه أومن قبل المحطة وبعدها يمكن حساب الإحداثيات المطلقة اعتماداً على موقع المحطات. 

يقوم الجهاز المحمول بالقيام بهذه الحسابات اعتماداً على حل برمجي ولكن لا بد من عملية تحديث البنية الصلبة للجهاز أيضاً لدعم -۴ 
.OTD‏ 

مما سبق نرى أن تقنية 8-015 توفر حل دقيق وبكلفة مقبولة. حيث يمكن الوصول إلى دقة تصل حتى 50 إلى 100 متر. 


يوضح الشكل التالي بنيان تقنية ٤-01‏ : 


Base Station 1 


Base Station 2 
Base Station 3 


A-GPSg GPS 


يُعتبر نظام تحديد الموقع العالمي 6۲S‏ من أكثر التقنيات شعبية في الوقت الحاضر. يستخدم هذا النظام 24 قمر صناعي عالمي تشكل 
مدار حول الأرض لإرسال إشارات إلى المستقبلات التي تدعم .6۲S‏ 
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يمكن للمستقبل الاتصال مع ثلاث أوأربع أقمار صنعية في أي لحظة. 
د هذه ١ا‏ لية كنة يجب أن يكون هناك خط نظر بين | لمستقبل والقمر الصنعي وهذا ما يمنع استخدام 8 ضمن الأبنية. 


عند حصول المستقبل على قياسات الموقع يمكنه حساب الإحداثيات مباشرة أوإرسال المعلومات إلى مخدم الشبكة لمعالجتها. 


بشكل مشابه لما يحصل في تقنية E-015‏ تعتبر عملية الحساب معقدة نسبياً وتحتاج إلى قدرة معالجة لا بأس بها.وإذا كانت الحسابات 


ب ل لار المعرل هه بج ل الق درد الحا مرف ف قل اق د قروا فاا سا ل 


في العديد من التجهيزات المحمولة يقدم مستقبل 6۲S‏ كوحدة منفصلة قابلة للوصل مع الجهاز المحمول باستخدام كابل أوبصورة 
لاسلكية باستخدام تقنية بلوتوث. 
بمعنى أن وحدة 6۴S‏ تحتوي الكيان الصلب المطلوب دون التأثير بصورة مباشرة على شكل الجهاز ة على استهلاكه للطاقة. 


إن أسعار الشرائح الصغرية الخاصة ب 6۲S‏ واستهلاكها للطاقة قد انخفض بشكل كبير في الآونة الأخيرة بشكل يقود إلى استخدام هذه 
التقنية بصورة مبيتة ضمن التجهيزات المحمولة. 

يعمل 6۴8 بشكل مشابه لتقنيات تحديد الموقع المعتمدة على النثليث , حيث تقوم الأقمار الصنعية ببث إشارات يمكن قراءتها من قبل 
التجهيزات التي تدعم .6۲S‏ 

ليس من المهم للقمر الصنعي عدد الأجهزة التي تستقبل هذه الإشارة لأن الاتصال يتم باتجاه واحد فقط. 


يقوم الجهاز المحمول بقياس كمية الزمن التي تتطلبها إشارة القمر الصنعي للوصول إلى الجهاز. تؤخذ هذه القياسات من ثلاثة أقمار 
مختلفة لإعطاء معلومات موقع أكثر دقة. 

رياضياً تتطلب العملية معلومات من أربعة أقمار لكن القياسات من ثلاثة أقمار كافية للحصول على معلومات لإعطاء دقة كافية.ولما 
کانت سرعة الإشارة محددة يمكن عندئد تحديد المسافة من القمر الصنعي. 

كما نلاحظ فمن الضروري أن تكون قياسات الزمن دقيقة جد فالخطاً في جزء واحد من ألف من الثانية قد يقود إلى خطاً في الموقع 
يصل إلى 300 كيلومتر. لهذا السبب تستخدم مستقبلات 6۴8 المعلومات القادمة من ساعة ذرية في كل قمر صنعي للتأكد من أن 
الزمن دقيق. 

بعد حساب المسافة عن القمر الصنعي يمكن أن تتم عملية التثليث وتحديد الإحداثيات المطلقة للجهاز المحمول. تزود هذه التقنية نتائج 


بدقة تتراوح بين 5 وحتى 40 مترا عن الموقع الأصلي. 
يجب ألا ننسى أيضاً أن معلومات الموقع التي تزودها أنظمة 6۶8 تتضمن إحداثيات الطول والعرض والارتفاع أيضا. 


بالرغم من كون الأنظمة التي تعتمد 6۴S‏ تزود معلومات موقع دقيقة لكنها ليست متفوقة بشكل كبير. لأنه كما ذكرنا سابقا وللحصول 
على قراءة يجب أن يكون هناك خط نظر مع القمر الصنعي. وهذه النقطة تعد محدودية كبيرة بالنسبة للأعمال المحمولة.فالعديد من 
التطبيقات تتطلب الاستخدام ضمن الأبنية أوالعربات مما يجعل من الصعب على 6۲S‏ تزويد الخدمة المطلوبة.قد تكون أحد الحلول 
لنقطة الضعف هذه استخدام طريقة 10۸-۳61 كطريقة داعمة. 
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أحد المشاكل الأساسية الأخرى هي الزمن اللازم لتحديد الموقع باستخدام هذه التقنية قد يتراوح بين 0 إلى 40 ثانية وهورقم كبير جداً 
يحول دون استخدام العديد من التطبيقات. 

أحد الحلول التي تتجاوز نقطتي الضعف الأساسيتين في 6۲8 هي استخدام ما يسمى ۸-6۲8 أونظام تحديد الموقع العالمي المدعوم 
حيث يستخدم هذا النظام أجهزة محمولة معدلة تقوم باستقبال معلومات 6۲5 ثم إرسال القراءات إلى مخدم الشبكة. يقوم الأخير 
باستخدام مستقبلات 6۴5 أخرى (وهي تشكل جزء من الشبكة) لإعانة المعلومات التي يقدمها 6۴5 الخاص بالجهاز المحمول. 


يتم توزيع مستقبلات 6۲8 الخاصة بالشبكة عبر الشبكة بمسافات تقدر بمئات الكيلومترات. تقوم هذه المستقبلات باستقبال معلومات 
8 المرسلة من قبل القمر الصناعي وتقوم بتزويد الأجهزة المحمولة بهذه المعلومات بشكل يزودهم بالقدرة على حساب الفوارق 
الزمنية دون الحاجة إلى فك تشفير الرسالة القادمة مباشرة من القمر الصنعي. 

تخلق هذه العملية فرق كبير جدأً في الزمن اللازم للحصول على معلومات الموقع حيث يصل الزمن المطلوب إلى حوالي ثماني ثواني. 


أما بشأن المحدودية المتعلقة بخط النظر فيقوم الجهاز المحمول بإرسال معلومات القياسات إلى مخدم الشبكة بحيث تتم عمليات الحساب 


المعقدة عليه. تسمح قدرة المعالجة بحسابات تقليل المسارات المتعددة وتحليل الإشارة لتحديد موقع الجهاز ضمن المبنى وفي الأماكن 
التي يصعب فيها تحديد الموقع بالأسلوب التقليدي. 


تستخدم تقنية مستقبلات 6۴8 بصورة مرتبطة مع أنظمة المعلومات الجغرافية لتزويد مشهد طبوغرافي للمناطق المختلفة ضمن البلاد. 


أحد أكثر استخدامات تطبيقات 6۲8 شيوعاً هي نظام تحديد الموقع الخاص بالعربات وخدمات التتبع. تتطلب هذه الخدمات أكثر من 
مجرد تحديد الموقع لجعلها فعالة وهنا يأتي دور أنظمة المعلومات الجغرافية. 
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GPS Satellites 


GPS-enabled GPS-enabled 
Device Base Station 
61S ما هو نظام المعلومات الجغرافية‎ 


يشكل تحديد موقع الأجهزة المحمولة أحد الجوانب فقط في عملية تزويد الخدمات المرتبطة بالموقع. فالحصول على إحداثيات الموقع 
ضروري بالطبع ولكن ما نفعله بتلك الإحداثيات لا يقل أهمية. 


ا اا مات رة ر عار عن بر تاع كان رف ار ا رب مارات ار مارك ا ت ا ا 


يتم الوصول إلى هذا عادة باستخدام خرائط متعددة الأبعاد للمعلومات تتضمن مثلاً لمواقع الأبنيةء ولتوضع الشوارع» ولكثافة السكان 
وللكتير من المعلومات الأخرى. 


يتألف نظام المعلومات الجغرافية المتكامل من الكيانات الصلبةء والبرمجيات» والبيانات» وأشخاص مدربين يعلمون كيفية إجراء عمليات 
التحليل على معلومات التي يزودها النظام. 


تفيد أنظمة 618 في تحقيق غرضين أساسيين: 
- إيجاد معالم معينة: تفيد د اة كي خاد رمات عن مقن معا ما رعق سا تلن هن ال اة أقرب مطعم 


Universal Knowledge Solutions s.a.1 
290 


أومحطة وقود مثلا أوتحديد المسار الأفضل للوصول إلى مكان محدد. 

إيجاد نموذج أوتشكيل ما: ترتبط هذه القدرة بتحليل الأعمال وهي لا تكم قط من التجهيز ات التحدولة كمك الأعمان عاد 
بمعرفة توزيع المعلومات بدلا عن المعلومات الإفرادية عن معلم ما. على سبيل المثال عند محاولة تحديد مكان لعقد مؤتمر مثلاً قد 
تكون أحد المعلومات الهامة تحديد المنطقة التي يتواجد فيها عالبية الأشخاص المستهدفين بهذا المؤتمر. 


من الواضح تماما أن فائدة أنظمة 61S‏ كبير ة للتطبيقات المحمولة ولكن هذه الأنظمة تقدم فوائد تتجاوز ما هومطلوب للبيئة المحمولة 

فيما يلي أهم استخدامات هذه الأنظمة: 

ت إيجاد ما يوجد في الجوار: يعد هذا الاستخدام من أكثر الاستخدامات شيوعاً ولمستخدمي التجهيزات المحمولة. بإعطاء موقع محدد 
يقوم النظام بإيجاد كل المراكز ضمن نصف قطر محدد. قد تتضمن هذه المراكز المراكز الصحية» المطاعم» محطات الوقودء 
أوحتى مراكز البيع لمواد معينة. 
معلومات التوجه: وهي أحد الاستخدامات المهمة أيضاً بالنسبة لمستخدمي التفنيات المحمولة. 
المعلومات التنبيهية: حيث قد يرغب بعض المستخدمين بالحصول على معلومات تهمهم حين تصبح قريبة من موقع تواجدهم على 
سبيل المثال تبيه بوجود ازدحام مروري على الطريق الذي يعبره المستخدم. 
كثافة التموضع: وهي معلومات تحليلية قد تكون مفيدة للكثير من الأعمال كتحديد مواقع الكثافة الأعلى للجرائم على سبيل المتال. 
كميات التموضع: وذلك لتحديد أين تنحصر مناطق التوزع الأعظمية والأصغرية لخدمة ما. 


تطوير أنظمة الخدمات المتعلقة بالموقع 


فتحت الخدمات المتعلقة بالموقع الباب أمام أسواق جديدة لكن هذه الخدمات تتطلب بيئة عمل معقدة تستخدم تقنيات متعددة وطرق مختلفة 


قد تقود إلى نفس النتيجة. 


ومع عدم توفر خبرات متراكمة في هذا الموضوع بعد يصبح موضوع تطوير تطبيقات 1858 موضوعا صعبا نسبيا. 


يقدم مزودوا الخدمة حاليا واجهات برمجية للتطبيقات ۸۴1 للوصول إلى معلومات الموقع وهي بصورة عامة واحدة من نوعين: 
- واجهات التطبيقات البرمجية المبنية على الشبكة: حيث تتوفر معلومات الموقع على مخدم الشبكة ويمكن الوصول إليها من أي 
طرف يمتلك الصلاحية المناسبة. 
- واجهات التطبيقات البرمجية المبنية على الجهاز المحمول: حيث يتم توليد معلومات الموقع على الجهاز ويمكن الوصول إليها 
بشكل مباشر عن طريق التطبيقات العاملة على الجهاز. 


توفر أغلب الحلول المتعلقة بالموقع واجهات برمجية للمطورين. يتم الوصول إلى معلومات الموقع عن طريق مركز تحديد الموقع 
النضرل € بك استكام نفس الولجهة ابر مج بغض النظر عن الققية المستخدمة فى تختيد المرقع وباكالى ترفير طبقة تجريدية 
للمطورين. 

يك وجرد 120 خطرة بالاتجاه الصسح بالفسبة المظررين ولكتها لا تحل كل المشاكل» تظل كن من التسياك الى يجب تجارزها 
وا لافس الطاهة ئى القن م اقترل ون ال ل ك ان كون 
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الشتع السابع عشز والثامن عقر 
تمارين وأمثلة 


نتعامل في هذه الجلسة العمل مع بعض التمارين المتكاملة التي تهدف إلى صقل الخبرات التطبيقية لبعض الأفكار التي تمت تغطيتها 
خلال جلسات هذه المادة. 

أهداف تعليمية: 

يتعرف الطالب في هذا الفصل على: 


€ كيفية استخدام 0نلداء سء¡ للوصول إلى تطبيق عامل 


€ بعض التقنيات التطبيقية الخاصة باستخد ام ملفات 1س× وقواعد بیانات اMSSQ‏ و sیە›ء٥۸ M8‏ کمصادر للبیانات. 
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أمثلة عامة 


تم تخصيص الجلستين الأخيرتين في هذه المادة لاستعراض مجموعة من الأمثلة المتكاملة التي تستخدم التقنيات 
التي تعرفنا عليها ضمن الجلسات الماضية ضمن إطار حل بسيط متكامل. 


المثال الأول : 
المتطلبات اللازمة للعمل على هذا المثال هي: 
- توفر ڊأة llتÙطıgر Visual Studio .NE—T‏ 
Microsoft Mobile Internet Toolkit‏ والتي يمكن الحصول عليها بتحميلها عن طريق الرابط 


.http://www.microsoft.com/downloads/details.aspx?familyid=ae597f21-b8e4-416ea28fb124f41f9768&displaylang=en 


هذا المثال عبارة عن مثال لتطبيق بسيط يحاكي آلة ۸1١۷‏ ولكن بدون القدرة على إجراء مناقلات حقيقية. 
الغرض من هذا المثال إظهار المقدار الحالي للمبالغ المتوفرة في حساب ما. 


1- قاعدة البيانات: باعتبار أن هدفنا في هذا المثال ليس التركيز على قاعدة البيانات وتصميمها سنقوم باستخدام 
أبسط شكل يخدم هدف مثالنا: 


tblUJsers tblAccouınts 
LISEF_ID eeamemaeaeaekekeج‎ LISEF_ID 
LIserhlarme Zhecking 
Password Savings 
FullMarmmE LreditLine 


نلاحظ أننا استخدمنا هنا جدولين الأول خاص بالمستخدمين و الثاني خاص بالحسابات 
2- من بيئة ۷8.٤1‏ نقوم باختيار إنشاء مشروع جديد من النمط 
.Mobile Web Application‏ 
E RET‏ جم امن اقات و التصركن اتر مدد اها لاف 
MobileWebForm.vb g MobileWebForm.aspx‏ (إذا اخترنا لغة 
Visua1 basic‏ للتطویر). 
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| Solution Explorer - MabileWebûpplication1 HMH 
1 Solution 'MabileYebApplication1' (1 project} 
E1. 1 Mobile¥¥#ebApplication1 
Hr ê] Referenres 


8 ûAssemblyInfo, Yb 
lobal, a5a 


Êz] MobileWebForm1 .a=p+ 
[Ëğ web.config 


Solution Expl... ez lass Yi | Û Resource Yie,,,‏ و 
4- باستخدام التبويب الحاوي على عناصر تحكم نماذج الوب المحمولة سنقوم بجر عناصر 1٥×)80×‏ و 
Button ڪy Label‏ . 
5- ستتألف صفحة الوب لدينا من ثلاث نماذج 
- الأول خاص بإدخال معلومات تسجيل الدخول وهو من الشكل 


- الثاني خاص باختيار نوع الحساب وهو من الشكل: 


ك 
[hecking tear [ê |‏ 


- أما الثالث فخاص بإظهار النتائج وهو من الشكل: 
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Hr. ify sar نو‎ 


[Savings accoun [#1 


E 
sirac asal 
اا ا ت ا | م س‎ 


6- لدى إضافة عناصر التحكم المختلفة يتم تلقائياً إضافة النص البرمجي لصفحة 
Mobile WebForm1 .asp>‏ ويصبح النص البرمجي كما يلي: 


<%5@ Page Language="vb" AutoEventWireup="false" Codebehind="Mobi lewebForml.aspx. vb" 
Inherits="Mobi leWebApplication1 .Mobi leWebForm1" %> 

<%5@ Register TagPrefix="mobile" Namespace="System.Web.UI.MobileControls"™ 
Assembly="System.Web.Mobile" %> 

<HEAD> 


Me Ea COREE E IMICEOSOE E UIA SUN SEALS CNM VN name CENERATORS 
<meta COREenN E VISUal BS NEN IE mame CODE UANCUAGE > 
<meta CORNTENE= INEEBE//SChemMas MA CEOSOEE . COM/MOBI Le Eade E 
name="vys_targetSchema"> 
</HEAD> 
Body SNIRS MOBILE =. REEPE/1SCheMaS Mi CEOSOEE. COM/ MOB LEV NEDE OEMS 
MOOI Tle ROEM A= RoOrMIL EUMaAaE=ISer VEE L> 
<P>Welcome to Account View</P> 
E OE 
<mobile:TextBox id="txtUserName" runat="server"></mobile:TextBox>Password 
moO Ue Mex BOX OL EXEPASSWOE AL EUNaA EE See L> MOB Ne: Hex EBON 
<mobile:Command id="cmdOK" runat="server">OK</mobile:Command></P> 
</mobile: form> 
MODA le EOEM IAL ETMAECECOURE UI eWNL EUNaAE = LSeFMEOE LS 
<P>Welcome to Account View </P> 
<P>Hello 
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<mobile:TextBox id="txtAccountViewName" runat="server"></mobile:TextBox>Select An 
J E LO 
MOB Le: celle e EROS E AAS lEeC ORIS E EUMAE <S e> 
cuEeMm Male 1O. Mex t> OMECKIRS ACCOR LE CEE 
u Cem Malle ll. EXE AVIS ACECOUNEL > ECEME 
<Item Value="2" Text="Credit Account"></Item> 
</mobile:SelectionList> 
:Command id="Command1" runat="server">OK</mobile:Command></P> 
</mobile: form> 
MODE le E OEM MEL EEMReSMLESL BUNA LSER LS 
<P>Welcome to Account View </P> 
<P>Hello 
<mobile:TextBox id="txtOutputName" runat="server"></mobile:TextBox>Account Type 
<mobile:TextBox id="txtOutputAccountType" runat="server"></mobile:TextBox>Account 
Balance 
<mobile:TextBox id="txtOutputAccountBalance" runat="server"></mobile:TextBox> 
<mobile:Command id="Command2" runat="server">Back</mobile:Command></P> 
</mobile: form> 
BONY 


أما النص البرمجي في lلخlفıة‏ ؤx.vصas. :MobileWebForm1‏ 


"System and SQL Namespaces 
IMPOE ES SvsEtem. Data 
IMOOE ES SVSECeMN Data. SGC HERE 
Public Class MobileWebForml 
"Mobile Namespaces 
iner IES SVSEEeM Web. Ul Mob leCOREE OLS Mobile age 
"ihe SOUECE COde COMERS MoOTUe COMEEOLLS EVENNESS UM CMES 
"section such as the two protected WithEvents shown below: 


Protected 
System.Web. 
Protected 
Protected 
Protected 
Protected 
Protected 
Protected 
Protected 
Protected 
Protected 
Protected 
Protected 


hEvents Password As _ 

.MODILECORNEEONS . abe LJ 

REvVeNES EOEMI AS SVSEEeM. WED. UI MOBI leCOR EEOLS BOE 

hEvents txtUserName AS System.Web.Ul.MobileControls. TextBox 

hEVentS LxXLPasswWword AS System.Web. UI.MoObiIlEeCoOntEols. TextBox 

REVERIE S SelIECEIORMISEl AS System Web UL MODA LECORNEEOLS. SelEC EI ONLI SE 

hEvents cmdOK As System.Web.UI.MobileControls. Command 

hEvents frmResults As System.Web.UI.MobileControls.Form 

hnEvents frmAccountView As System.Web.UI.MobileControls.Form 

hnEvents Command2 As System.Web.UI.MobileControls. Command 

hEvents txtAccountViewName As System.Web.UI.MobileControls. TextBox 

hEvents Command1 As System.Web.UI.MobileControls. Command 

hEvents txtOutputName As System.Web.UI.MobileControls. TextBox 
Protected REVeNES BEX COUEPUEAGEOMRE Ivpe AS SVSEOM. WEB. UL MOON eCORE EOS. le XEBOX 
Protected hEvents txtOutputAccountBalance As 

SMS Ee MOS. UI MOC LECOREEONS HEX EBDO 


3 3 
pe pe po pe pb pe pe pc pe pc pc pe pÛ- GQ fp: 


1 


قمنا او لا کما نری باستیر اد فضاء الأسماء والتصريح عن جمیع عناصر التحكم المستخدمة. 
Ho lUSWInNS COoRSEaANES Gene Ehe EVEe GE ACCOUNE VOU WaNE EO GUCeEY‏ 
EUbDINE CORSE CHECKING AcSEOUNE = 0‏ 


BUSI E CORSE SAVINGS ACCOR < 
BUD IENS CORSE CRED mne 2 


عرفنا هذه الثوابت لغرض استخدامها كبدائل عن استخدام الأرقام في تحديد نوع الحساب. 


EEiva lte SUG CMAOK CITEKKBYVUal Senders AS SVSEeM. OBIEeCE, BVVal € AS SUSECM EVENEAEGS) 
Handles cmdOK.Click 
'Get the username,if its a valid username then 
mMavidga Ee EO ACOOUNE VIEW EOEM 
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& 


Dim SEEUSES AS SEEING 
strUser = GetUserName (txtUserName. Text, txtPassword. Text) 
If Len(strUser) > 0 Then 
ActiveForm = (frmAccountView) 
Else 
Response.Write ("Invalid Username and/or Password") 
O JME 
Ena SUb 


الطريقة السابقة خاصة بمعالجة حدث الضغط على زر ”0۸“ في النموذج الأول حيث سيتم اختبار اسم 
المرور وكلمة السر باستخدام الj¦طريقة Get UserName‏ 


Private Function GetUserName (ByVal sUserName As String, ByVal sPassword As 
SEF) AS SEETRS 
'Get Username based on txtName.Text and 
TEXEBASSWNOEG.lextE EFEOM EDIUSEES 
Salle SEEUSEeE AS SEEING 
TE LeN(SEEUSEE) = O0 Then 
Dim sql As String = "SELECT * FROM tblUsers Where tblUsers.UserName ='"'" 
sUserName & "'AND tblUsers.Password =_" 
SSE ASSMOEA GCE 
"Use ADO.NET Data Reader to get the data 


Dim conn As New SqlConnection ("workstation id=SKAIT;packet 
Si Ze = 409G; IEEE ESS SOC MCV SBN da ES SOME CESK ANL E BOEESISE SOCEM EY 
mE oO=Ea LSE ART EIaAKE Cala lOS=ACCOUME SL) 

Dim comm As New SqlCommand (sql, conn) 

Dim reader As SqlDataReader 

conn. Open () 


reader = comm. ExecuteReader 
hile (reader.Read() ) 
SErFUSeE = (Eeader (lEul INamel)) 
End While 
conn.Close() 
conn = Nothing 
comm = Nothing 
reader = Nothing 
End IE 
GetUserName = strUser 
aE. UNE E LOM 


يقوم التابع السابق كما نرى بعملية اتصال مع قاعدة البيانات باستخدام الأغراض ١0اءم«مه۳‏ 1هي 
Sq1DataReader «SqlCommand‏ نلاحظ هنا أننا استخدمنا إعلةS412a)aRe‏ بسبب عدم الحاجة إلى 
إجراء أي تعديل على البيانات. 


BEI va Ee SUS COMnandl CITERK(BVVal sender AS SvVSEeM ObJect, BVVal @ AS 
SVYSEem.EvVeNEAEGS) Hanales COommandl CU TEE 

"navigate to the results form using Activeform 

NEE VEE OEM = (EEMREeSULES) 
HAGA SU 


تمثل الطريقة السابقة معالج حدث ضغط زر 0K‏ في النموذج الثاني بعد اختيار نوع الحساب. 


EE Va Ee SUG EEMReSUIES Activate (ByVal Sender AS SVSstem Object, BVVal e AS 
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System.EventArgs) 
'get the data based on account type and username and then 
"format the result 
Dim intOption As Integer 
DIM SEFOUE UE AS SEEING 
intOption = (SelectionList1.SelectedIndex) 
'0 =Checking,1 =Savings,2 =Credit Line 
EXE OU EPUEACEOMRER VEGE: eX E () > Selec IONS EN. Se leCE TOR TEeEXE 0) "Account 
TOE 
LxtOutputName. Text = GetUserName (txtUserName. Text, txtPassword.Text) 'Get the 
name 
txtOutputAccountBalance.Text = Format$ (Get_Account_Balance(intOption), 
"SHH. FHF, FHEF.O00") 

"Eel Ehe dEeCoOUnNE Valle and forme Elle SEEING 
RAGA SUS 


تمثل الطريقة السابقة معالج حدث تفعيل النموذج ءاااء ۲R‏ والذي سيقوم بإظهار النتائج. 


Private Function Get_Account_Balance (ByVal intAccountType) As Double 
"Classic use of SQL data reader,it is atomic read, 
elosoes he Connect TON 
'get the account balance based on relationship with the Table() 
Dim sql As String = "SELECT *FROM tblAccounts, tblUsers Where 
tblAccounts.User_ID = tblUsers.User_ID And tblUsers.UserName ='" & txtUserName. Text & 
"TAND EbDIUUSEeES EBaSSWOEd Nl € EXCEASSWOEd. lex & lT 
Dim conn As New SqlConnection ("Data Source=localhost; Integrated 
SOEUE IEYV=GSSBU IRA EMAN CaEANOIT=ACEOURES LL) 
Dim comm As New SqlCommand (sql, conn) 
Dim reader As SqlDataReader 
Dim dblAccountValue As Double 
conn. Open () 
reader = comm. ExecuteReader 
Sele e ê Case MAEAECCOURE YPS 
Case CHECKING_Account 
hile (reader.Read() ) 
JSONRAE COUR EMULE > Val (EEA SE ( CMEC EIN 
End While 
SAVINGS_ATCEOURNE 
hile (reader.Read() ) 
QABIAcCEOUnNEValUe = Val (Eeader (LSeVIRNOSL)) 
End While 
CREDIT Line 
hile (reader.Read() ) 
dJDLAECECoOUnNEMa le >= Val (Feader ( LCE ed ELI Re 8)) 
End While 
End Select 
conn.Close() 
conn = Nothing 
comm = Nothing 
reader = Nothing 
Get_Account_Balance = dblAccountValue 
ERA EURE E TOR 
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ا E‏ ا ا کل ر کاب لاک لان 
قام بتسجيل الدخول. 


Private Sub Command2_Click (ByVal sender As System.Object, ByVal e As 


System.EventArgs) Handles Command2.Click 
"Navigate to account view 
ACEI OEM < FEMAGECOU REME 


Ena SUB 
معالج الحدث الخاص بالنقر على زر ع8 في النموذج ءااuاوم ۲.۸ للعودة والاستعلام عن نوع آخر من‎ 
الحسابات.‎ 


Private Sub frmAccountView_Activate (ByVal sender As System.Object, ByVal e As 


System.EventArgs) 
"Welcome the user 
txtAccountViewName. Text = GetUserName (txtUserName. Text, 


ENG SUB 


LXLPaAaSSWOEd. Text) 


Private Sub InitializeComponent () 


ERA SUS 
CLASS 


7- لسهولة العمل توفر بيئة ۷5.٤8١‏ آلية لإنشاء وتصميم قاعدة البيانات من ضمن بيئة التطوير وذلك من 
خلال إظضھار liذiة :Server Explorer‏ 


RH x 


1 dy SKAIT Accounts, dbo 
SEAIT dba 
1. E servers 
Û- BH skar 
se Crystal Services 
Event Logs 
1. mË Message QUEIJES 
ا‎ Performance Zounters 
n SEFYÎCE: 
1 FF SOL Servers 
SEAIT 
3 Accounts 
E چ3‎ Database Diagrams 
5 Tables 
i tblaccounks 
i B~ tblllsers 
- Hh Views 
28 چ‎ Stored Procedures 
l: ۍ‎ Functions 
- Î master 
H- ê mode 
1 # msdb 
I tempdb 


حيث نلاحظ كيف قمنا هنا بإنشاء قاعدة البيانات ك« ء٠۸‏ التي تحتوي الجداول المطلوبة 


8- يمكن إضافة طرق أخرى لمثالنا تقوم بعمليات السحب من حساب ما مثلاً و ستكون على غرار تلك التي 
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استعملناها في الاستعلام عن حساب. 

9- أصبح بإمكاننا الآن أن نقوم ببناء تطبيقنا باستخدام الأمر 0۸نtں]اهS‏ dاBui‏ من القائمة .8ui1d‏ 

10- بعد التأكد من كون تطبيقنا موجود ضمن المسار المناسب في مجلد ضمن 00۲ WR‏ ۷0۷ أو مُعرف 
ضمن مجلد افتراضي من خلال 118 والتأكد من تفعيله كتطبيق يمكننا تشغيل تطبيقنا المصغر عن طريق 
مستعرضات مختلفة لاختباره. 


11- يمكن هنا أيضا استخدام أنواع مستعرضات غير مدعومة ومحاولة ثأمين الدعم لها باستخدام 


موائمات أجهزة و ضبط الإعدادات من ملف عاگدWeb.c0.‏ 


المثال الثاني 
سنعمل في هذا المثال على حل يتعلق بتحديث حالة الطقس على الأجهزة المحمولة. سنستخدم في مثالنا ملف ×XM1‏ 
كمصدر لبيانات حالة الطقس (حيث يمكن أن يتوفر مثل هذا المصدر بسهولة). 
للتعامل مع هذا المصدر سنستخدم الصف ١ءل2ء‏ 1۸× حيث سيقوم هذا الغرض بفراءة الملف الحاوي على 
معلومات الطقس و الممثلة بالعناصر »>min> » >forcast> «<updated> « <cİy<‏ <axےص>.‏ سیکون ملف 
XM‏ من الشکل: 


xml ver SION I OL a> 
<weatherinfo> 

<auckland> 

<updated>31/01/2002 09:00</updated> 
EM EV aUEKLaREA SV CO REVS 
<forecast>Fine. A mostly sunny day with light winds</forecast> 
MRE 2A CAMER 

<max>25</max> 

</auckland> 

<chennai> 

<updated>31/01/2002 09:00</updated> 
EM EY Chea CV CA E 
<forecast>Fine.</forecast> 
MARE G9 VME 

<max>38</max> 

</chennai> 

<hongkong> 

<updated>31/01/2002 09:00</updated> 
eR Ey MORO ORO CEE 
<forecast>Early rain</forecast> 
BE 2 MANS 

<max>25</max> 

VRORGEORO 

<mumbai> 

<updated>31/01/2002 09:00</updated> 
E EY RMUMOaA TL CES 

<forecast>Sunny day</forecast> 
MIRE 29 CAMER 

<max>35</max> 

</mumbai> 

<malaysia> 

<updated>31/01/2002 09:00</updated> 
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<forecast>raining</forecast> 

I 2A A < O 

<max>25</max> 

</malaysia> 

<newdelhi> 

<updated>31/01/2002 09:00</updated> 
EM EY > MewWde LRT O EV 
<forecast>Fine</forecast> 
MADE CO UMER 

<max>35</max> 

</newdelhi> 

<newyork> 

<updated>31/01/2002 09:00</updated> 
EU EV RNEWYVOE K<7 CA EY > 

<forecast>Very Cold</forecast> 
<min>24</min> 

<max>25</max> 

</newyork> 

<singapore> 

<updated>31/01/2002 09:00</updated> 
E EVE SERS POE ES ACES 
<forecast>rain day</forecast> 

TM SO LAME 

<max>35</max> 

</singapore> 

<tokyo> 

<updated>31/01/2002 09:00</updated> 
ELE MZE OOS E > 

<forecast>sunny day </forecast> 
<min>22</min> 

<max>25</max> 

VEOkK YS > 

<sydney> 

<updated>31/01/2002 09:00</updated> 
SEN EVE SVABEY MEE 
<forecast>Fine</forecast> 
MABE 21< MIR 

<max>25</max> 

</sydney> 

<washington> 

<updated>31/01/2002 09:00</updated> 
EREY WASHER ESR CES 
<forecast>Fine.very cold</forecast> 
MIRE 2S GAMERS 

<max>25</max> 

</washington> 

</weatherinfo> 

//XML File End 


إذا اردنا الان كتابة النص البرمجى الخاص بقراءة وإظهار معلومات هذا الملف فسيکون من الشكل: 
"Source Code Starts‏ 
eC Pade IRO ES" MSEEM We. UN CMOS LECOREROLS MOBS lLEEa Gel MARO UASE= VOL >‏ 
Register lagE Felix moO lel Namespace SVSEEM . We UI ‘Mob leCOREE OLS‏ @6< 
Assembly="System.Web.Mobile" $%>‏ 
@Import Namespace="System.Xml"$%>‏ %< 


<script runat="server"> 
BUDE SUD LEASE CIM ECKE VENE HaNG ler (BYU SOU ECSNl AS ODIECEl, BUN ê A5 
ListCommandEventArgs) 
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Dim weatherReader As XmlTextReader = Nothing 
weatherReader = New XmlTextReader (weatherFileName) 
Dim selectedcity As [String] = e.ListItem.Value 
hile weatherReader.Read() 

f weatherReader.NodeType = XmlNodeType.Element Then 

f weatherReader.Name = e.ListItem.Value Then 

athena bel — e. LISELI eM. eX 1 COMEEOLCHNAES UE {1 WealtlNer. 

f weatherReader.LocalName. Equals ("updated") Then 

atherLabel = WeatherLabel + ControlChars.Lf + weatherReader.ReadString () 
El JE 
f weatherReader.LocalName. Equals ("city") Then 
atherLabel = WeatherLabel + weatherReader.ReadString () 
ERG UE 
f weatherReader.LocalName. Equals ("forecast") Then 
atherLabel = WeatherLabel + weatherReader.ReadString () 
RG UE 
f weatherReader.LocalName.Equals ("min") Then 

atherLabel = WeatherLlLabel + "Min Temperature:" + weatherReader.ReadString () 
ERA UE 
f weatherReader.LocalName. Equals ("max") Then 

atherLabel = WeatherLabel + "Max Temperature: + weatherReader.ReadString () 
O UE 
ERI TE 
ERS LE 
End While 
ActiveForm = weather 
End SOB TENSE CIICGKEVENEHSNONEE 
VSEOEIOES 

MSE OE CME eS 
MODAN e: ROEM EUMaAlE = SOE VEE 
<mobile:Label runat="server">Select a City</mobile:Label> 
MOAN e: ASE EUMaAE<LSOF VEE! AOS ECME VALE 
OnTéEemCommand= LA SE CIO REVeNEHanNEOleEN > 
<item Text="Auckland" Value="auckland" /> 
<item Text="Chennai" Value="chennai" /> 
EeMm Hext TIONG KONSL Vale > "RONSEORNIL U 
<item Text="Mumbai" Value="mumbai" /> 
<item Text="Malaysia" Value="malaysia" /> 
<item Text="New Delhi" Value="newdelhi" /> 
TEemM ext New HOEK ValUeE > NeUYVOKL > 
<item Text="Sydney" Value="sydney" /> 
<item Text="Singapore" Value="singapore" /> 
eem Text oko Value =lEokyol 7> 
<item Text="Washington" Value="washington" /> 
Mme BNE EIS E> 
</mobile:Form> 
MOLLE EHO UMD IE SHEQEVESE TOE HSOCOAOE OEM > 
<mobile:Label runat="server" id="WelcomeMessage" /> 
mo BDINe EOE 
MOB E ROEM TA weather UNSE = LSGEVEE LS 
<mobile:Label runat="server" id="WeatherLabel"/> 
</mobile:Form> 

"Source Code End 


نلاحظ أننا قمنا بإدراج النص البرمجي كجزء من الصفحة دون فصله ضمن ملف منفصل. 
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المثال الثالث 
سنقوم في هذا المثال بتخصيص إعدادات تطبيق بناء على المستخدم الذي سجل الدخول إلى هذا التطبيق» حيث يعد 
هذا الأسلوب فعالاً جداً للحصول على رضا الزبون وللتخفيف ما أمكن من ظهور معلومات غير مهمة لهذا المستخدم 
کل خاضن: 
يتألف مثالنا من تطبيق محمول لإظهار أسعار الأسهم حيث سيتمكن المستخدم من الوصول إلى أسعار الأسهم التي 
یختار رمزها. 
يمكن للمستخدم حفظ الخيار الذي قام به وفي المرة التالية التي يسجل فيها دخوله سوف يتم إظهار معلومات هذه 
الأسهم بشكل له بشكل خاص. 
سنقوم باستخدام قاعدة بیانات sیعء۸ 1S‏ مع هذا المثال ونقوم باستخدام جدjılg Tb1IStock, Tb1User‏ 
سنستخدم في هذه المرة #€ 


Pwd 


UserID [rext 
۳ 


User ID ext 
StockSymbols 


يخزن الجدول )ء٥1515‏ المعلومات من الشكل مؤشرات الأسهم الخاصة بكل زبون وذلك بالشكل: 


User1 


1 ê CSCO,NT ,„XRX 


ملاحظة: بالطبع سيكون من المنطقي في نظام فعلي عدم تخزين معلومات كلمات السر بشكلها الصريح . 
سيلزمنا أولا إجراء بعض التغييرات إلى الملف عاگرهء.طwe:‏ 


التغييرات السابقة ستحول عملية التحقق من الهوية لتصبح مهمة النموذج في الصفحة ×صءه."عه! حيث يتم إدخال 
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انس لعجل و كلها المرور وها قرع لمرد > سخ جي المتكم من فة المهة إلى اله اطا ب في 
حال ت قرل قله دا أرلا يتمم صفحة شل الفخرل: 


3 
Password: 


و لما كنا قد اخترنا استخدام قاعدة بيانات كءعء٥۸‏ فسنقوم بجر عنصر التحكم الخاص بالاتصال بقواعد البيانات 
0€Db۳Connection‏ وإنشاء اتصال يدل على قاعدة البيانات وذلك بضبط |عدادIٽ .ConnectionString‏ 


: S1 أيضا ونحدد خاصة‎ ١0٥۳١1۳214 بعدها سنقوم بجر عنصر التحكم الخاص‎ 
SELECT COUNT (UserID) AS Exprl1 FROM tblUser WHERE (Pwd = ?) AND (UserID =?) 


سيتم استخدام غرض K01١14214‏ للتحقق من المستخدم 
النص البرمجي التالي يوضح طريقة معالج الحدت الخاصة بالنقر على زر ١أع0اماط.‏ 


Private Sub btnLogin_Click (ByVal sender As Object, ByVal e As System.EventArgs) 
leDbCommandl1.Parameters. Add ("Pwd", OleDbType.VarChar, 50) 
leDbCommand1.Parameters ("Pwd") .Value = txtPwd. Text 
leDbCommandl1.BParameters.Add ("UserID", OleDbType.VarChar, 50) 
leDbCommand1.Parameters ("Userld").Value = txtUser.Text 
leDbConnection1. Open () 

im nCount As Integer = CInt (oleDbCommand1.ExecuteScalar () ) 
OLEDESCORMeE EA OMICS Se J 

TE mMEeoUneê — ll Then 
MobileFormsAuthentication.RedirectFromLoginPage (TextBox1. Text, True) 
ERS TUE 

ERAS SUB BEDNLOGERICLTER 


صفحة الوب المحمول: 

ستتألف صفحتنا الأساسية هنا من نموذج وحيد يظهر فيه اسم المستخدم ورموز الأسهم وتظهر قيم أسعار الأسهم 
ضمن جدول. 

يمكن للمستخدم تعديل تفضيلات الإعدادات المستخدمة. 
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2 
lIpdate Stock Symbols | 
3 
Refresh MHuotes | 


3) 
Column) 


E 


العناصر في هذا النموذج وحسب الترتيب هي Label - TextBox-Button-Button-ObjectList طaill ja‏ 
للتعرف على المستخدم سنقوم باستخدام lئخزlصة Context.User.Identity.Name‏ 

وبنفس الطريقة التي قمنا باستخدامها لتسجيل الدخول سنقوم بإضافة عنصر تحكم c)10۸م”Con€eDbا0‏ وعنصر 
تحكم ل21 0e2 ٣0۳‏ ونحدد الخاصة 1×٤‏ 2«dصصهع‏ إلى القيمة : 


SELECT StockKSymbolSs, USerld EROM tblISEOCK WHERE (USerld = 2) 


يأخذ النص البرمجي لتحميل الصفحة الشكل: 


Private Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) 
IE Not ISESSEBaCK Men 

UserName = Context.User.Identity.Name 

Labell.Text = UserNam 

TextBoxl1.Text = GetSymbolsForUser () 

FillQuotes (TextBox1l. Text) 

OG E 

End SUS Eade Toad 

Code Snippet : Display Che USeE GS pEererences aNd the ual les GE ERhe SEOCK GUOEOS, 
EE a Ee BUNGELON Gelt SVMOOlSEOEUSeE (J) AS SEEING 
oleDbCommand1.Parameters (0).Value = Context.User.Identity.Name 
oleDbConnection1l . Open () 

Dim strSymbols As String = CStr (oleDbCommand1.ExecuteScalar () ) 
oleDbConnectionl1.Close() 

Return SstrSymbols 

ERA EUnNECETONn CGeEGVMOONSEOEUSEE 


أما الطريقة التي ستقوم بإظهار أسعار الأسهم فهي التالية: 
EE va Ee SUG EIN LOUOEeS (EVVaLl SEESYMOOoOLS AS SEEFTIRO)‏ 
Dim req As HttpWebRequest‏ 
Dim res As HttpWebResponse‏ 
Dim sr As StreamReader‏ 
DEM SEERe SMILE AS SEHEDE‏ 
Dim lempe (J) AS SEEING‏ 
DIM EeNPI (O AS SEEDS‏ 
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DI SEENON AS SEU 

DET EOMISAERN AS SERIN) 

Dim ds As New DataSet 

de Males AAS LEL S EEL) 

Dim SymbolColumn As New DataColumn 

SymbolCOoO umn. Data lype — SYSEeM. lyPe. Ge IYGEe ( SVSE OM. SEEIRSIL) 
SymbolColumn.ALlowDBNull = True 

SyYmooO LCE UMA. CapE LON = SVMS 

SymbolColumn. ColumnName = "StkSymbol" 
SymbolColumn.DefaultValue = "Stock" 

' Add the column to the table. 

dS. Tables ( EBDLISEK TT COLUM S ASS (SYMOO LLCO UME) 

'get stock quote for each row 

Dim PriceColumn As New DataColumn 

BEI EeCS LMR. Dal alye <> SVSEeM TVOE Ce EMSC LSMSEEM Decimal) 
ıe 1 COCO RR. AL LOBEL = TES 

E BNOSOCGO LNCAP ENON > WEE HEE 

EEN eeCOL N CO UmMaAName = CEKEN GEL 

EE LESCOL N . DEE aL EMNE = Û 

' Add the column to the table. 

AS Male S (E EOS. COURS ASAR EEE eC SLUR) 

EemMp - SEESVMOOLS.SPLUTE (SEPE E AE OE) 

If temp.Length > Û0 Then 

Dim di AS InEeSEeE 

For i = 0 To temp.Length - 1 

EUSA — METPE1GUSEe vVaRooO COM IALaUSEeS CSVES 1 1 TEMP) 
"gf=sl1d1t1clohgvjl1pp2owern&e=.csv" 

TEV 

req = CType (WebRequest.Create(fullpath), HttpWebRequest) 
res = CType (req.GetResponse(), HttpWebResponse) 

sr = New StreamReader (res.GetResponseStream(), Encoding.ASCII) 
SErReSULE > SE RedSALIReN ) 

sr.Close () 

Eempl — SERRESMLE.SPUTTE (SOP EE A EOE) 

If templ.Length > 1 Then 

"only the relevant portion. 

SERE UE A RSexX = Kem) 

Dim myRow As DataRow = ds.Tables("tblStk") .NewRow () 
MYROW (CO) > Ee (A) 

myRow (1) = Convert. ToDecimal (strcurindex) 

d5. Tables (UEBDISEK TY) ROWS ASO (MYROW ) 

OE, E 

Cat eh 

RG May 

Next 1 

OD JecEISEL.DaltaSOoUEcGe > GJS. lables ( LEOISEKY) Def AU EVIE 
OBbDjEeCEMISEL. Dat aB1 RQ (J) 

Ob eC EMS ENTAB LSE LES SS LSE OMNI SEKEENEGSN 

ERS TE 

End SOG EM INOMOEES 


أما الطريقة الخاصة بمعالجة حدث نقر زر Refresh Quote‏ 


Private Sub Command3_Click (ByVal sender As Object, ByVal e As System.EventArgs) 
FillQuotes (GetSymbolsForUser () ) 
End SOG Commands CICK 


Universal Knowledge Solutions s.a.1 
306 


ولتحديث الرموز الخاضة بالمستخدم نلجاً إلى استخدام نفس الطريقة المتبعة سايقا للاتضال بقاغدة البيانات باستخدام 


غرض ٤٥0۸١8٥10٩‏ وغرض C002۸‏ مع تحديد قيمة ٥٥٣٣2۸11 ٤×٤‏ إلى القيمة 


نقوم هنا كما نلاحظ بتمرير المعاملات لاستعلام 501 وذلك لتحديث الرموز الخاصة بالأسهم المفضلة لدى 
المستخدم. 


أما النص البرمجي الخاص بمعالج حدث ضغط زر تسجيل الخروج فهو كما يلي: 


أما مصدر بيانات أسعار الأسهم فسيتم استجلابها من موقع ۷4100 بحسب ما يرد في النص الكامل للبرنامج و ذلك 
من المسار التالي. 
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I0: Î serl CECO 


serr Tl SikSymbol: CSCO 


Password: LIpdate Stack Surmbal SlkPrIice: 13.04 
| pdate Stock Symbols 1 ET 


Refresh Quotes 


SBtkESyYmbol 
MSET 


ُ 


Default.aspx انلف‎ 


<%5@ Page Inherits="System.Web.UI.MobileControls.MobilePage" Language="VB" 
Debug="true" %> 

<%5@ Register TagPrefix="mobile" Namespace="System.Web.UI.MobileControls"™ 
Assembly="System.Web.Mobile" %> 

Import Namespace="System" %> 

Import Namespace="System. Data"%> 

Import Namespace="System.Data.OleDb" %> 

Import Namespace="System.Net" $%> 

Import Namespace="System. Text" %> 

Import Namespace="System. IO" %> 

Import Namespace="System.Web.Mobile" %> 

<script runat="server" language="VB"> 

EUS SEE AS SEES 

BUDDIES SEFCOND AS SEEING = IPEOVIIeE MICTOSOE E Vet OLEDE. 40; DBDaAEa 

SOME CEC, INE EPUS WMUWEOOE KEI SR IMO AOA MADE 

EBEivate Separator AS Char (J) > lG 

Protected oleDbConnectionl As OleDbConnection 

Protected oleDbCommandl As OleDbCommand 

Protected oleDbCommand2 As OleDbCommand 

Private strUserName As String 

Private Sub Page_lLoad(ByVal sender As Object, ByVal e As System.EventArgs) 
oleDbConnectionl = New OleDbConnection (strConn) 

oleDbCommandl1 = New OleDbCommand 

oleDbCommand2 = New OleDbCommand 

uf Nol ISEOS EEalek Wen 

strUserName = Context.User. Identity .Name 

Labell1.Text = strUserName 

TextBoxl.Text = GetSymbolsForUser () 


0 


NN 
ol o0 


AA 
o0 


o0 


o0 
O @ @ @@ @ @ @ 


0 
o0 
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ERS TUE 

End Sub 'Pağge_ Load 

Private Sub Command1_Click (ByVal sender As Object, ByVal e As System.EventArgs) 
GLEE E 

MODI leê OE MRSA EREN EA Ea ETON. SIGROUE () 

RedirectToMobilePage ("login.aspx") 

End SUD Commandl CI Tek 

EE wa Ee SUG EIN LOUOEeS (EVVaAL SEESYMOOLS AS SEE TRS) 

ELS EURNCEIORN MA LN EEC SEOCKE GUSEOS EOE CACM SESE SUMNOSL SECTS By EME USGE 
and populate Eme data IM ad dataltable, Ie data 1S EIN ly SOURS EO am ODJECELISE , 
Dim req As HttpWebRequest 

Dim res As HttpWebResponse 

Dim sr As StreamReader 

DIM SERRE SULE AS SEET 

Dim eem () AS SEEING 

Di EMO (J) AS SEL E 

DI SEEM OES AS SEE AG) 

DEM EUAN AS SEIN 

Dim ds As New DataSet 

dE Hales AAA LEDLSEEL) 

Dim SymbolColumn As New DataColumn 

SymoolCOlumMA Data lype = SVSEeM. TYPE: GEL IVE ( SVSEEOM. SERIN) 
SymbolColumn.ALlowDBNull = True 

SYmooO LLCO AMR. CapPELON > SYMON 

SymbolColumn.ColumnName = "StkSymbol" 
SymbolColumn.DefaultValue = "MSFT" 

'"' Add the column to the table. 

dS Mable S( TEBDLSEK EONS. ASIA SYVTEOS LCOS UME) 

'get stock quote for each row 

Dim PriceColumn As New DataColumn 

BEE eCSLURR Dat aly Oe > SVSEeM. TVPe Ce E IVE LSMSEEM Decimal) 
iE CECOL U AL LOR DENULL = TEMS 

E ENE COLUMN CAP ENON > UPEIEGEL 

EER eeCO LUMA: CEoOlUMAName > CEKEN GEL 

EEN ee CO LUM. Beal EVae — 0 

' Add the column to the table. 

dS Male S( CEOS EE) EONS ASA (EETEeC SLUR) 

Eem@ <= SEESVUNOSLS SPINE SOOAE AE OE ) 

If temp.Length > Û0 Then 

DEM i" AS InEegeE 

O 1 = O0 US EES. CEES 

Fula — Mi EPE/1GUSte yahoo Com IlaUotes. esSves ll 1 EMD) 
"gf=sl1d1t1cl1ohgvj1pp2owern&e=.csv" 


TEY 

req = CType (WebRequest.Create(fullpath), HttpWebRequest) 
res = CType (req.GetResponse(), HttpWebResponse) 

sr = New StreamReader (res.GetResponseStream(), Encoding.ASCII) 
SEReSM LE — SE ReSdLIRe() 

SE. Close () 

Eempl — SERREeSMLUE SPITE (SOPE AEOE) 

If templ.Length > 1 Then 

"only the relevant portion 

SERO UE RG ezS = eM) 

Dim myRow As DataRow = ds.Tables("tblStk") .NewRow () 
MYROW (O) = Cemo (A) 

myRow (1) = Convert. ToDecimal (strcurindex) 

dS: Tables ( EBDLISERT ) ROWS AAS (MYROW ) 

OG TIE 

CEE EI 

3 O WE 
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OD ec EIS ELDalaSOUEGE > JS. lableS(LEOLSEEL) Bef AU EVIE 

ODI ee ELI SEL. DataBInd() 

OB eC EMS EN Ma DLSE TELES < SECON SEREENESL 

ERS UE 

EG Sulo Sl TOUOESE 

Private Sub Command2_Click (ByVal sender As Object, ByVal e As System.EventArgs) 
"the following Code Will Update Ehe SEoOeCkK SVMOOL preferences 4S Specified bY the 
user. 

OLED COMA ZA : CONRECS EON < COIEDEHCONROGE 1O 

oleDbCommand2. CommandText = "UPDATE tblStock SET StockSymbols = ? WHERE 
Userld = ?)" 
oleDbCommand2.Parameters.Add (New System.Data.OleDb.OleDbParameter ("StockSymbols", 
System. Data.OleDb.OleDbType.VarWChar, 255, "StockSymbols") ) 
oleDbCommand2.Parameters.Add (New System.Data.OleDb.OleDbParameter ("Original_Userld", 
System.Data.OleDb.OleDbType.VarWChar, 50, System.Data.ParameterDirection. Input, 
False, CType (0, System.Byte), CType(0, System.Byte), "Userld", 
System.Data.DataRowVersion.Original, Nothing) ) 

oleDbCommand2.Parameters (0) .Value = TextBox1. Text 

oleDbCommand2. Parameters (1).Value = Context.User.Identity.Name 
oleDbConnection1l . Open () 

oleDbCommand2. ExecuteNonQuery () 

olEeDECOnRReEG E1 on Close 

BINIOUOE eS (Ge ES YMOOI SEO USEF ()) 

End SOD Command CINE 

Private Sub Command3_Click (ByVal sender As Object, ByVal e As System.EventArgs) 
"Refresh the stock quotes 

FillQuotes (GetSymbolsForUser () ) 

End SO Command SCI Ek 

EEN va Ee BUNGCEILON Get SVMOOlSEOEUSEeE() AS SEEING 

"Fetch the preferences specified by the user from the database 

OLED COMRNARNGL -CONRESEION <= OlIODOCORNROGE 1O 

oleDbCommand1 .CommandText = "SELECT StockSymbols, UserlId FROM tblStock WHERE (Userld 
2) " 
Me.oleDbCommand1.Parameters. Add (New System.Data.OleDb.OleDbParameter ("UserlId", 
System.Data.OleDb.OleDbType.VarWChar, 50, "UserlId")) 
oleDbCommand1.Parameters(0).Value = Context.User.Identity.Name 
oleDbConnection1l . Open () 

Dim strSymbols As String = CStr (oleDbCommand1 .ExecuteScalar () ) 
oOleDOCOnRnReEGCENOnRI CoS e 0) 

Return strSymbols 

End Function 'GetSymbolsForUser 

VESEY 

MOAN e: ROEM MOA < EOL BUMAE < LSE ELS 

<mobile:Label id="Label1" runat="server">Label</mobile:Label> 

<mobile:TextBox id="TextBox1l" runat="server"></mobile:TextBox> 

amoeba le E oOMnNa Rd A= COMNARdZ ES EUMAE = 1 SEF VER 

ORCI eK = Command 2 Cl eR >UBdate SEOCKE SUmbol S< mobi le :eommand > 

MODA le: E ommend a= COMMaRd SE EUMAE = SOF VO ORCI CK = COMMAS S CIL EKR REEF ESM 
Quotes</mobile:Command> 

MOM e ODIEE EASE EA OD ECEM SELL CUNE lL SCEUEE 1 LAOENSEYI CG SEVERE eR eREE <> LEI EEeL 
CommandStyle-StyleReference="subcommand"></mobile:ObjectList> 

MObBA 1 e: Commend 1ad Commandl st FUMAlE = SSE Ve 

Om EL ele E ommMa REN CEE LE EO GOUE MOB Le: Command 

</mobile:Form> 


والملف >×صLog1n.asp‏ 


<%$@ Page Inherits="System.Web.UI.MobileControls.MobilePage" Language="VB" 
Debug="true" %> 
<%@ Assembly Name="System.Web" %> 
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ssembly="System.Web.Mobile" $%> 
@ Import Namespace="System" %> 

@ Import Namespace="System.Data"$%> 

@ Import Namespace="System.Data.OleDb" %> 

@ Import Namespace="System.web" %> 

@ Import Namespace="System.web. Security" %> 

@ Import Namespace="System.Web.Mobile" %> 

SEE ISE EUNaE= SCeEVeEN ANGUS Ie VBL 

ONL SES AS [OECTA | 

BMD e SEECONn AS SERIN = CEEOVUISISE=MAGCEOSOE E Wet OEEDE 4 0F Bata SOUECe = 
IRE EPUB WWW OSE BE SDI ABI MADE 

Protected oleDbCommandl1l As OleDbCommand 

Private Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) 
oOlLEDECEORREE EA oN = New OleDOCORNNECETOR {SEE CONE) 

oleDbCommandl1l = New OleDbCommand 

ERdA SUS Eade Load 

Private Sub Command1_Click (ByVal sender As Object, ByVal e As System.EventArgs) 
"login using the credentials specified by the user 

oOleDOCOmMNRaAnNGAT ConnecE On = oOleDbCONRNeCE ION 1 

oleDbCommand1 .CommandText = "SELECT COUNT (UserID) AS Exprl FROM tblUser WH 
2Y AND USSD = 
oleDbCommand1.Parameters.AQdd ("UserId", OleDbType.VarChar, 50) 
oleDbCommand1.Parameters (0) .Value = txtPwd. Text 
oleDbCommand1.Parameters.AQdd ("UserId", OleDbType.VarChar, 50) 
oleDbCommand1.Parameters (1) .Value = txtUser.Text 
oleDbConnection1l . Open () 
Dim nCount As Integer = 
OLEDOCORREEC ENON CoS e 
iE COU 2> M1 MANN 
MoOBD1 IESE MSA EREN E ACA E ION. REQAIFEeCEEEONUOISIARNEAITe (EX EUSEr .lexE, IEUe) 

OE, E 

ERE SUS Commanadl CIIeGk 

GAECELIES 

moe E OEM Td >= VEOEMUL UNAL SEE VERS 

<mobile:Label id="Label1" runat="server">ID:</mobile:Label> 

<mobile:TextBox id="txtUser" runat="server"></mobile:TextBox> 

<mobile:Label id="Label2" runat="server">Password:</mobile:Label> 

<mobile: TextBox id="txtPwd" runat="server" Password="True"></mobile:TextBox> 
MOAN e E oOMRARNAd A= EMA EOSIN EUNAE=— 1 SOF VER 

SACI Eek = Command CI VER SE LOSI SMOB le CE oOmMMEREI> 

</mobile:Form> 


CInt (oleDbCommand1.ExecuteScalar () ) 


وسيأخذ الملف عنگصهء. ط٥۷‏ بعد التعديل الشكل : 


Gl OEE SAORI OY EERE EEE GY F> 

OSB HE UE AE HORS 

<Ssystem.web> 

<compilation defaultLanguage="VB" debug="true"/> 

SOUS EOMEEEOES MmMode= LO E> 

SAU E MEME NEA AON MOde = EO MSL 2 

i GEMS LOGUE l= NOGA ASPX Mame AGERE OORTUEAUERAE aE l> 
</Forms> 

</authentication> 

<aUtRNOFEI Zat 1oOn> 

<deny users="?2" /> 

VaUEhOrIZation> 

SEFaECe enabled= lal sel EeGUESELIMI E101 PaSeOMEPUE=LfEal Sel EEACeMOde= OE EBV MeL 
LOCO E ONS 


Universal Knowledge Solutions s.a.1 
311 


SGLCORME CEM OMSK ERS Oa Ea SOUECE A2 O ON USES OG SA; PBA SSNOEO= COOKIE eS SL EEE 
Eme oU 2O 

<globalization requestEncoding="utf-8" responseEncoding="utf-8" /> 

| <httpRuntime useFullyQualifiedRedirectUrl="true" /> 

<mobileControls cookielessDataDictionaryType="System.Web.Mobile.CookielessData" /> 
SIEM GEN EOE S > 

ENI Ee Mame >I SHUM Z2L COMPA EERE R OEE CARERNIEEIRGEY GEL AFG UmMmeERE >Em > 
E NI Ee Mame > SVM COMOAEE LEE ef CEEFCEARERNIERINGS EYEE QAEGUMEORME <M 

E Iker Male =i SCHIMEL OT COMPA e EE ef SE EEARERIEEINOTVSEL ar OUMeENtE = CREM > 
<filter name="isGoAmerica" compare="Browser" argument="Go.Web" /> 

<filter name="isMME" compare="Browser" argument="Microsoft Mobile Explorer" /> 
<filter name="isMyPalm" compare="Browser" argument="MyPalm" /> 

<filter name="isPocketIE" compare="Browser" argument="Pocket IE" /> 

<filter name="isUP3x" compare="Type" argument="Phone.com 3.x Browser" /> 

E A Rame =1 i SUEBA4xX' COMOar e=lIvVPe" ar GUNeNE =" ENORNe. COM 4.< Br OWSerS > 

E Û J mame = l1 SEE ICS SORE S90 CoOmMpaEe = IvVBEl AEOUNENE=LEEIESSON RISO > 

E mame >A SORE aA ION COMBA e> MVGeEl aoa umen E> NOR a UO 

E name="prefersGIF" compare="PreferredImageMIME" argument="image/gif" /> 

E name="prefersWBMP" compare="PreferredImageMIME" argument="image/vnd.wap.wbmp" 
ج‎ 
E J mame =1 SUSE OEESEOLOEL COMEAE E = MSE OLO AE OMRON = LEE Ue > 

E mame = I SUPPOE E SCOOK TES COMPar e COOK 1ES aFoUmenE= LEE Ue 1> 

<filter name="supportsJavaScript" compare="Javascript" argument="true" /> 

<filter name="supportsVoiceCalls" compare="CanInitiateVvVoiceCall" argument="true" /> 
</deviceFilters> 

</system.web> 

< CORE LOWES LORE 
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قراءات اضافية: 


http://www.w3schools.com/dotnetmobile/default.asp 
http://www.aspnextgen.com/MobileQuickStart/(qz3zcSygksjxka4Se4wwv2uf)/Default.aspx 
http://www.asp.net/default.aspx?tabIndex=3&tabId=44 


http://www. wirelessdevnet.com/channels/wap/ 


http://www.microsoft.com/downloads/details.aspx?FamilyID=8fb566e0-3e92-40e8-b5d4- 
091dO05ab8829&DisplayLang=en 
http://www.ondotnet.com/pub/a/dotnet/2004/02/23/mobilewebserviceapps.html 
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